笔者在本机的虚拟机下进行的安装,数据库已经装好了的。
ubuntu16.04 x64
postgresql:9
wildfly10
下载必要软件包(直接到官网下载即可):
本次笔者把以上的软件都安装在 /opt 目录下
登录操作系统的用户名为 royoan,以下所有操作都是该用户操作
jdk的安装就不说了,注意环境变量的设置 JAVA_HOME.
笔者是在已有的 test数据库上创建了一个用户和一个该用户的schema,这样相当于一个新的数据库。
--登录数据库test增加一个用户和模式 create user ejbca password ‘ejbca‘; CREATE SCHEMA ejbca AUTHORIZATION ejbca;
解压apache-ant-1.10.1-bin.tar.gz 到/opt目录下,得到 /opt/apache-ant-1.10.1
配置环境变量,修改 /home/royoan/.profile文件,在该文件的最后 插如如下代码
export JAVA_HOME=/opt/jdk1.8.0_131 PATH="$JAVA_HOME/bin:$PATH" export ANT_HOME=/opt/apache-ant-1.10.1 PATH="$ANT_HOME/bin:$PATH"
保存后,执行
$:/opt$ source ~/.profile $:/opt$ cd /opt $:/opt$ ant Buildfile: build.xml does not exist! Build failed
出现如下Build failed 提示,表示ant装好了
同样解压文件包到/opt目录得到
/opt/wildfly-10.0.0.Final目录
执行如下命令启动wildfly服务器:
cd /opt/wildfly-10.0.0.Final bin/standalone.sh
把postgresql-9.4.1207.jar 文件放在 /home/royoan/ 目录下,待wildfly启动后执行如下命令:
jboss-cli.bat -c
该命令会进入命令行工具内,执行如下cli命令安装模块
module add --name=org.postgresql --resources=/home/roy/postgresql-9.4.1207.jar --dependencies=javax.api,javax.transaction.api
该命令会在JBOSS_HOME/modules下面创建一个目录
|-org/postgresql/main
|-module.xml
∟-postgresql-9.4.1207.jar
增加驱动 和增加数据源 的cli命令:
/subsystem=datasources/jdbc-driver=postgresql:add(driver-name="postgresql",driver-module-name="org.postgresql",driver-xa-datasource-class-name=org.postgresql.Driver) data-source add --name=ejbcads --driver-name="postgresql" --connection-url="jdbc:postgresql://localhost:5432/test" --jndi-name="java:/EjbcaDS" --use-ccm=true --driver-class="org.postgresql.Driver" --user-name="ejbca" --password="ejbca" --validate-on-match=true --background-validation=false --prepared-statements-cache-size=50 --share-prepared-statements=true --min-pool-size=5 --max-pool-size=150 --pool-prefill=true --transaction-isolation=TRANSACTION_READ_COMMITTED --check-valid-connection-sql="select 1;"
以上命令会修改 standalone.xml配置文件,请注意上面的url,username,password按照你的数据库配置实际填写。
同样是在cli命令行下执行命令:
/subsystem=remoting/http-connector=http-remoting-connector:remove /subsystem=remoting/http-connector=http-remoting-connector:add(connector-ref="remoting",security-realm="ApplicationRealm") /socket-binding-group=standard-sockets/socket-binding=remoting:add(port="4447") /subsystem=undertow/server=default-server/http-listener=remoting:add(socket-binding=remoting) :reload
配置日志:
/subsystem=logging/logger=org.ejbca:add /subsystem=logging/logger=org.ejbca:write-attribute(name=level, value=DEBUG) /subsystem=logging/logger=org.cesecore:add /subsystem=logging/logger=org.cesecore:write-attribute(name=level, value=DEBUG)
解压 ejbca_ce_6_5.0.5.zip 到/opt 目录;并进入解压后的文件夹。
conf目录中是ejbca的配置文件,在build和生成CA的时候会读取这个文件中的一些设置,里边的配置文件都是以.sample结尾的,如果我们要修改默认的配置就要把需要修改的文件重命名,把.sample去掉
我们需要修改一下几个文件,先生成4个个重要的文件:
cd /opt/ejbca_ce_6_5.0.5/conf
mv ejbca.properties.sample ejbca.properties mv web.properties.sample web.properties mv database.properties.sample database.properties mv install.properties.sample install.properties
修改 ejbca.properties 文件
设置 appserver.home 的值(就是应用服务器的安装位置,对于我们来说是 /opt/wildfly-10.0.0.Final)
修改 web.properties 文件
设置CA的超级管理员的证书密码,以及给应用服务器生成的服务器端证书的证书密码,和CA的truststory的密码等,这些密码的设置我们可以根据需要设置,或者保持默认的配置,需要注意的是httpsserver.hostname,这个要和后边的alias相对应,我的ip地址为 147.128.105.149,那这里我们设置为147.128.105.149
修改 database.properties文件
实际上只要使用wildfly的数据源即可 。把 datasource.jndi-name=EjbcaDS 的注释取消, 还要把 数据库类型database.name=postgres这个注释也要放开。否则安装出错,会执行h2数据库的库表安装脚本。笔者就是没有打开这个选项导致第一次安装出错。
修改 install.properties 文件
设置CA的名称,加密方式等,建议保持默认即可。
进入命令行,执行如下命令:
cd /opt/ejbca_ce_6_5.0.5/ ant clean deployear ant runinstall ant deploy-keystore
deployear的那步时间会久一点,
ant runinstall 当移除了一个已存在的安装(有可用的TLS keystore)的时候,不需要执行该步命令。这句话说实话还没看懂。
ant deploy-keystore 这步执行完,会在ejbca目录下会生成keystore.jks, truststore.jks, 脚本会自动拷贝到 $JBOSS_HOME/standalone/configuration/keystore,我们不用管。
同样在 /opt/wild 目录中执行 jboss-cli.sh -c 进入cli命令行交互界面;执行如下cli:
/subsystem=undertow/server=default-server/http-listener=default:remove /subsystem=undertow/server=default-server/https-listener=https:remove /socket-binding-group=standard-sockets/socket-binding=http:remove /socket-binding-group=standard-sockets/socket-binding=https:remove
/interface=http:add(inet-address="0.0.0.0") /interface=httpspub:add(inet-address="0.0.0.0") /interface=httpspriv:add(inet-address="0.0.0.0") /socket-binding-group=standard-sockets/socket-binding=http:add(port="8080",interface="http") /subsystem=undertow/server=default-server/http-listener=http:add(socket-binding=http) /subsystem=undertow/server=default-server/http-listener=http:write-attribute(name=redirect-socket, value="httpspriv")
:reload
上面的"0.0.0.0"表示其他机器也可以访问了,原来默认是127.0.0.1就说明只能本机访问。
接着配置realm , socket-binding,注意两个密码,这里的 alias 就是前文提到的要配置ip地址。
/core-service=management/security-realm=SSLRealm:add() /core-service=management/security-realm=SSLRealm/server-identity=ssl:add(keystore-path="${jboss.server.config.dir}/keystore/keystore.jks", keystore-password="serverpwd", alias="147.128.105.149") /core-service=management/security-realm=SSLRealm/authentication=truststore:add(keystore-path="${jboss.server.config.dir}/keystore/truststore.jks", keystore-password="changeit") /socket-binding-group=standard-sockets/socket-binding=httpspriv:add(port="8443",interface="httpspriv") /socket-binding-group=standard-sockets/socket-binding=httpspub:add(port="8442", interface="httpspub")
执行完了后,退出 jboss-cli.sh
停掉 wildfly, 重新启动。(一定不要忘记了)
重新进入 jboss-cli.sh -c
执行:
/subsystem=undertow/server=default-server/https-listener=httpspriv:add(socket-binding=httpspriv, security-realm="SSLRealm", verify-client=REQUIRED) /subsystem=undertow/server=default-server/https-listener=httpspriv:write-attribute(name=max-parameters, value="2048") /subsystem=undertow/server=default-server/https-listener=httpspub:add(socket-binding=httpspub, security-realm="SSLRealm") /subsystem=undertow/server=default-server/https-listener=httpspub:write-attribute(name=max-parameters, value="2048") :reload
然后是一些重要的配置
/system-property=org.apache.tomcat.util.buf.UDecoder.ALLOW_ENCODED_SLASH:add(value=true) /system-property=org.apache.catalina.connector.CoyoteAdapter.ALLOW_BACKSLASH:add(value=true) /system-property=org.apache.catalina.connector.URI_ENCODING:add(value="UTF-8") /system-property=org.apache.catalina.connector.USE_BODY_ENCODING_FOR_QUERY_STRING:add(value=true) /subsystem=webservices:write-attribute(name=wsdl-host, value=jbossws.undefined.host) /subsystem=webservices:write-attribute(name=modify-wsdl-address, value=true) :reload
如果你在wildfly前面还装了个Apache服务,那么还要执行如下命令,否则不用执行:
/subsystem=undertow/server=default-server/ajp-listener=ajp-listener:add(socket-binding=ajp, scheme=https, enabled=true) :reload
下载证书 /opt/ejbca_ce_6_5.0.5/p12/superadmin.p12 到本地, 然后导入浏览器,即可访问后台了()因为需要双向认证)
ejbca的管理后台
https://147.128.105.149:8443/ejbca/adminweb
大功告成!!!
本文版权归作者 royoan(博文地址:http://www.cnblogs.com/royoan/p/7763633.html)所有,欢迎转载和商用,请在文章页面明显位置给出原文链接并保留此段声明,否则保留追究法律责任的权利,其他事项,可留言咨询。
EJBCA安装教程+postgresql+wildfly10
原文:http://www.cnblogs.com/royoan/p/7763633.html