所以,我将环境变量从 bash 传递到 python;
#!/usr/bin/env python2
import os
#connect("weblogic", "weblogic", url=xxx.xxx.xxx.xxx:xxxx)
os.environ['bash_variable']
通过 wlst.sh 我可以打印导出的 bash_variable,但是如何执行存储的变量?基本上,我试图删除原始的连接语句并传递一个包含上述信息的变量。谢谢
最佳答案
问题是,为什么不使用变量作为参数来调用脚本并使用 sys.argv[] ?
举个例子,像这样。
import os
import sys
import traceback
from java.io import *
from java.lang import *
wlDomain = sys.argv[1]
wlDomPath = sys.argv[2]
wlNMHost = sys.argv[3]
wlNMPort = sys.argv[4]
wlDPath="%s/%s" %(wlDomPath,wlDomain)
wlNMprop="/apps/bea/wls/scripts/.shadow/NM.prop"
try:
print "Connection to Node Manager"
print ""
loadProperties(wlNMprop)
nmConnect(username=NMuser,password=NMpass,host=wlNMHost,port=wlNMPort,domainName=wlDomain,domainDir=wlDPath,mType='ssl',verbose='true')
except:
print "Fatal Error : No Connection to Node Manager"
exit()
print "Connected to Node Manager"
NM.prop 文件是一个 600 文件,其中包含 NM 的用户名/密码。
编辑:
据我了解,您想做这样的事情:
URLS = ['t3s://Host1:Port1','t3s://Host2:Port2','t3s://Host3:Port3']
for urls in URLS:
connect('somebody','password',urls)
{bunch of commands}
disconnect()
列表 URL 的值将由环境定义。
在我看来,你有 3 个选择:
- 每个环境有 1 个脚本,URL 列表的保存或多或少相同
- 有 1 个脚本,但在 sys.argv[1] 上有条件分支(环境作为参数)并在那里创建列表。
- 有 1 个脚本,根据环境为每个环境使用参数文件。每个参数文件都包含相关列表。
类似的事情:
propENV = sys.argv[1]
propPath = "/path1/path2"
propFile = "%s/%s" %(propPath,propENV)
loadProperties(propFile)
我自己可能会使用属性文件选项,因为从操作的角度来看它更灵活......至少恕我直言。
关于python - WLST执行存储变量 "connect()"语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22359827/