


Explication détaillée de la façon de générer automatiquement la configuration du proxy inverse Docker Nginx à l'aide de Python
由于在测试环境上用docker部署了多个应用,而且他们的端口有的相同,有的又不相同,数量也比较多,在使用jenkins发版本的时候,不好配置,于是想要写一个脚本,能在docker 容器创建、停止的时候,自动生成nginx反向代理,然后reload nginx
我的原则是尽量简单,轻量,内存占用少
目标很明确,只要能监听到docker的容器启动/停止事件,即可
网上查了一下可以用docker events来监听docker事件,试了一下,发现基本可以满足,于是用python写了一段程序,用来监听docker事件
python
#!/usr/bin/python# coding: utf8import osimport jsonimport reimport subprocessdef 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 retdef 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 class="brush:php;toolbar:false">" + hosts + "")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
启动命令:
nohup ./docker.py > /dev/null 2>&1 &
程序会在后台运行,断开ssh也不会结束
主要就是生成一个 conf 文件,这个文件要在nginx.conf里面引入,然后每次有容器启动/停止都生成这个文件,然后重启nginx,我这了还把容器名加上一个域名,组合成了一个子域名,然后把对应的映射关系生成了一个html文件,通过浏览器可以访问这个文件,然后把对应的代码 复制到本机的 hosts 文件里面,可以实现通过域名访问应用,当然只是开发测试的时候会这么做,但是也足够了。
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Lorsque vous utilisez la bibliothèque Pandas de Python, comment copier des colonnes entières entre deux frames de données avec différentes structures est un problème courant. Supposons que nous ayons deux dats ...

Utilisation alternative des annotations des paramètres Python Dans la programmation Python, les annotations des paramètres sont une fonction très utile qui peut aider les développeurs à mieux comprendre et utiliser les fonctions ...

Choix de la bibliothèque de développement d'applications de bureau multiplateforme Python De nombreux développeurs Python souhaitent développer des applications de bureau pouvant s'exécuter sur Windows et Linux Systems ...

Comment les scripts Python effacent-ils la sortie en position de curseur à un emplacement spécifique? Lors de l'écriture de scripts Python, il est courant d'effacer la sortie précédente à la position du curseur ...

Pourquoi mon code ne peut-il pas faire renvoyer les données par l'API? En programmation, nous rencontrons souvent le problème du retour des valeurs nulles lorsque l'API appelle, ce qui n'est pas seulement déroutant ...

Comment Uvicorn écoute-t-il en permanence les demandes HTTP? Uvicorn est un serveur Web léger basé sur ASGI. L'une de ses fonctions principales est d'écouter les demandes HTTP et de procéder ...

Dans Python, comment créer dynamiquement un objet via une chaîne et appeler ses méthodes? Il s'agit d'une exigence de programmation courante, surtout si elle doit être configurée ou exécutée ...

De nombreux développeurs s'appuient sur PYPI (PythonPackageIndex) ...
