利用python自動(dòng)生成docker nginx反向代理配置
利用python自動(dòng)生成docker nginx反向代理配置
由于在測(cè)試環(huán)境上用docker部署了多個(gè)應(yīng)用,而且他們的端口有的相同,有的又不相同,數(shù)量也比較多,在使用jenkins發(fā)版本的時(shí)候,不好配置,于是想要寫一個(gè)腳本,能在docker 容器創(chuàng)建、停止的時(shí)候,自動(dòng)生成nginx反向代理,然后reload nginx
我的原則是盡量簡(jiǎn)單,輕量,內(nèi)存占用少
目標(biāo)很明確,只要能監(jiān)聽到docker的容器啟動(dòng)/停止事件,即可
網(wǎng)上查了一下可以用docker events來監(jiān)聽docker事件,試了一下,發(fā)現(xiàn)基本可以滿足,于是用python寫了一段程序,用來監(jiān)聽docker事件
python
#!/usr/bin/python
# coding: utf8
import os
import json
import re
import subprocess
def override(path, text):
if not os.path.exists(path) and os.path.exists(path+"_temp"):
os.rename(path+"_temp",path)
fw = open(path+"_temp", 'wb')
fw.write(text)
fw.close()
if os.path.exists(path):
os.remove(path)
os.rename(path+"_temp", path)
def read(path):
try:
fr = open(path, "rb")
except IOError:
print "The file don't exist, Please double check!"
return
lines = fr.readlines()
ret = ''
for line in lines:
ret += line
return ret
def read_jsonfile(path):
return json.loads(read(path))
def cmd(command):
return os.popen(command).read()
def get_name(container):
return cmd("docker inspect -f '{{.Name}}' " + container).replace("/", "").replace('\n', '')
def get_ip(container):
return cmd("docker inspect -f '{{.NetworkSettings.IPAddress}}' " + container).replace('\n', '')
def get_port(container):
return cmd("docker inspect -f '{{.Config.ExposedPorts}}' " + container).replace('/tcp:{}]', '').replace('map[', '').replace('\n', '')
def get_info(container):
filename = "/var/lib/docker/containers/" + container + "/config.v2.json"
config = read_jsonfile(filename)
name = config['Name'].replace("/", "")
port = config['Config']['ExposedPorts'].keys()[0].replace('/tcp', '')
ip = cmd("docker inspect -f '{{.NetworkSettings.IPAddress}}' " + name)
# ip = config['NetworkSettings']['Networks']['bridge']['IPAddress']
ret = {'name': name, 'port': port, 'ip': ip}
return ret
tpl = """
server {
listen 80;
server_name $name.test.com;
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://$ip:$port;
}
}
"""
def generate_conf():
print "generate_conf"
out = cmd("docker ps | grep -v CONTAINER | awk '{print $1}'")
containers = out.split("\n")
servers = ''
hosts = ''
for con in containers:
if con != '':
name = get_name(con)
ip = get_ip(con)
port = get_port(con)
print ip, port
if len(port) >= 2:
servers += tpl.replace("$name", name).replace("$ip", ip).replace("$port", port)
hosts += "11.12.13.14 " + name + ".test.com\n"
override('/usr/local/openresty/nginx/conf/vhost.conf', servers)
override('/usr/local/openresty/nginx/html/vhost.html', "<pre>" + hosts + "</pre>")
def reload_nginx():
print "reload nginx"
cmd('nginx -s reload')
def auto_reload():
generate_conf()
reload_nginx()
print " ==================== docker events ==================== "
# auto_reload()
proc = subprocess.Popen(["docker", "events"],
# shell=True, # windows: true, linux: false
stdout=subprocess.PIPE)
while 1:
out = proc.stdout.readline()
event = re.sub('\(|\)', "", out).split(" ")
if out.find('container stop') != -1:
auto_reload()
print ' container stop '
elif out.find('container start') != -1:
auto_reload()
print ' start container '
if out == '':
print "out "
break
啟動(dòng)命令:
nohup ./docker.py > /dev/null 2>&1 &
程序會(huì)在后臺(tái)運(yùn)行,斷開ssh也不會(huì)結(jié)束
主要就是生成一個(gè) conf 文件,這個(gè)文件要在nginx.conf里面引入,然后每次有容器啟動(dòng)/停止都生成這個(gè)文件,然后重啟nginx,我這了還把容器名加上一個(gè)域名,組合成了一個(gè)子域名,然后把對(duì)應(yīng)的映射關(guān)系生成了一個(gè)html文件,通過瀏覽器可以訪問這個(gè)文件,然后把對(duì)應(yīng)的代碼 復(fù)制到本機(jī)的 hosts 文件里面,可以實(shí)現(xiàn)通過域名訪問應(yīng)用,當(dāng)然只是開發(fā)測(cè)試的時(shí)候會(huì)這么做,但是也足夠了。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
Windows(Win11)如何安裝Docker(Docker Desktop)
這篇文章主要介紹了Windows(Win11)如何安裝Docker(Docker Desktop),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
Docker 使用國(guó)內(nèi)鏡像倉(cāng)庫(kù)的方法
這篇文章主要介紹了Docker 使用國(guó)內(nèi)鏡像倉(cāng)庫(kù)的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
Docker 鏡像國(guó)內(nèi)加速的方法匯總(收藏版)
本文介紹了在國(guó)內(nèi)使用Docker時(shí)遇到的加速和優(yōu)化方法,針對(duì)國(guó)內(nèi)下載速度慢和斷線問題,可以使用國(guó)內(nèi)可用的DockerRegistryMirrors或自建DockerRegistryMirror/Proxy,針對(duì)沒有公共鏡像庫(kù)賬號(hào)導(dǎo)致的限流問題,可以注冊(cè)各個(gè)鏡像庫(kù)賬號(hào)并登錄,感興趣的朋友跟隨小編一起看看吧2025-01-01
Docker 阿里云鏡像倉(cāng)庫(kù)CR使用小結(jié)
阿里云提供了免費(fèi)的容器鏡像服務(wù),更重要的是支持公開和私有倉(cāng)庫(kù),本文主要介紹了Docker 阿里云鏡像倉(cāng)庫(kù)CR使用小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02
Docker初級(jí)網(wǎng)絡(luò)端口映射的配置
這篇文章主要介紹了Docker初級(jí)網(wǎng)絡(luò)端口映射的配置,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02

