默认情况下,在jboss eap 6.2+ 管理控制台创建datasource后,会在standalone.xml(独立模式)或host.xml(域模式)中以明文保存相关敏感信息。
这会给服务器留下安全隐患,不过官方已经考虑到了这一点,给出了vault机制来进行加密,步骤如下:
1. 利用keytool生成keystore文件,参考命令如下:
keytool -genseckey -alias ctas -storetype jceks -keyalg AES -keysize 128 -storepass mypassword -keystore /Users/jimmy/vault/vault.keystore
解释一下:keytool是jdk自带的小工具
红色的部分是大家要根据自身情况修改的,蓝色的可改可不改。
-alias 后的ctas为别名,可以随便改
-storepass 后的mypassword为访问keystore文件的密码
-keystore 后的/Users/jimmy/vault/vault.keystore为keystore文件的保存路径,注:该文件jboss必须具有读写权限。
整个keystore相当于一个敏感信息的文件数据库,可以把一些敏感信息,比如db连接密码,ftp密码,邮件密码保存在这里。
蓝色部分AES为加密算法,可以改成RSA之类,128为加密强度,具体可参考jboss文档。
2. JBOSS_HOME/bin/vault.sh ,进入vault交互模式,会出现类似如下输出:
========================================== JBoss Vault JBOSS_HOME: /Users/jimmy/Downloads/app/jboss-eap-6.2 JAVA: /Library/Java/JavaVirtualMachines/jdk1.7.0_79.jdk/Contents/Home/bin/java ========================================== ********************************** **** JBoss Vault *************** ********************************** Please enter a Digit:: 0: Start Interactive Session 1: Remove Interactive Session 2: Exit 输入0,进入交互模式。
Starting an interactive session
Enter directory to store encrypted files:/Users/jimmy/vault/ 这里输入keystore文件所在目录 Enter Keystore URL:/Users/jimmy/vault/vault.keystore 这里输入keystore文件完整路径 Enter Keystore password: 这里输入keystore的密码,与刚才步骤1中的密码要相同 Enter Keystore password again: 再次输入密码进行验证 Values match Enter 8 character salt:20150720 撒点盐,大家根据需要修改(必须是8位字符) Enter iteration count as a number (Eg: 44):43 加密的迭代次数(可以随便改) Enter Keystore Alias:cnblogs 别名,可以随便改 这些弄完后,会输出下面这一段: Initializing Vault Jul 20, 2015 11:37:09 PM org.picketbox.plugins.vault.PicketBoxSecurityVault init INFO: PBOX000361: Default Security Vault Implementation Initialized and Ready Vault Configuration in AS7 config file: ******************************************** ... </extensions> <vault> <vault-option name="KEYSTORE_URL" value="/Users/jimmy/vault/vault.keystore"/> <vault-option name="KEYSTORE_PASSWORD" value="MASK-2W0YkkQmW8vbjUxlq79j/1"/> <vault-option name="KEYSTORE_ALIAS" value="cnblogs"/> <vault-option name="SALT" value="20150720"/> <vault-option name="ITERATION_COUNT" value="43"/> <vault-option name="ENC_FILE_DIR" value="/Users/jimmy/vault/"/> </vault><management> ... ******************************************** Vault is initialized and ready for use Handshake with Vault complete Please enter a Digit:: 0: Store a secured attribute 1: Check whether a secured attribute exists 2: Exit 注意:红色部分,意思是让你把这一段,加到standalone.xml或host.xml的相应位置。(注:建议把这一段复制出来,等会儿再加到配置文件中)
3. 保持刚才的交互模式,不要退出,继续:
输入0,准备存储敏感信息
Task: Store a secured attribute Please enter secured attribute value (such as password): 这里输入要存储的敏感信息,比如mysql的连接密码 Please enter secured attribute value (such as password) again: 再输入一次 Values match Enter Vault Block:ctasDS_PWD 容器别名,随便起 Enter Attribute Name:password Secured attribute value has been stored in vault. Please make note of the following: ******************************************** Vault Block:ctasDS_PWD Attribute Name:password Configuration should be done as follows: VAULT::ctasDS_PWD::password::1 ********************************************
注意红色部分,辛苦了半天,就是要这一行,最后按2退出,同时停止jboss(如果jboss在运行的话)
4.修改jboss配置文件,以standalone.xml为例
</extensions> <vault> <vault-option name="KEYSTORE_URL" value="/Users/jimmy/vault/vault.keystore"/> <vault-option name="KEYSTORE_PASSWORD" value="MASK-2W0YkkQmW8vbjUxlq79j/1"/> <vault-option name="KEYSTORE_ALIAS" value="cnblogs"/> <vault-option name="SALT" value="20150720"/> <vault-option name="ITERATION_COUNT" value="43"/> <vault-option name="ENC_FILE_DIR" value="/Users/jimmy/vault/"/> </vault> <management>
在</extensions>与<management>先插入第2步中刚才高亮大段标红的内容。如果是域(domain)模式,这一段要插入到host.xml文件的<management>之前,另外域模式下,每台slave机器的host.xml里都要做同样的处理,keystore文件也要复制到每台slave机器上。
然后找到testDS的位置(域模式下datasource是在master机器的domain.xml里),把密码换成:
<datasource jta="false" jndi-name="java:/testDS" pool-name="testDS" enabled="true" use-ccm="false"> ... <security> <user-name>root</user-name> <password>${VAULT::ctasDS_PWD::password::1}</password> </security> ... </datasource>
重启jboss,搞定。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有