溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

docker中怎么擴(kuò)展Python程序

發(fā)布時(shí)間:2021-11-16 13:57:23 來(lái)源:億速云 閱讀:149 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要講解了“docker中怎么擴(kuò)展Python程序”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“docker中怎么擴(kuò)展Python程序”吧!

將這個(gè)Python程序進(jìn)行一個(gè)擴(kuò)展,連接redis數(shù)據(jù)庫(kù),并對(duì)redis進(jìn)行一些操作,

新建App.py,內(nèi)容如下:

from flask import Flask
from redis import Redis
import os
import socket

app = Flask(__name__)
redis = Redis(host=os.environ.get('REDIS_HOST', '127.0.0.1'), port=6379)

@app.route('/')
def hello():
    redis.incr('hits')
    return 'Hello Container World! I have bean seen %s times and my hostname is %s. \n' % (redis.get('hits'), socket.gethostname())

if __name__ == "__main__":
    app.run(host="0.0.0.0", port=5000, debug=True)

新建Dockerfile,內(nèi)容如下: 

FROM python:2.7
LABEL maintainer="vincent"
COPY . /app
WORKDIR /app
RUN pip install flask redis
EXPOSE 5000
CMD [ "python", "app.py" ]

創(chuàng)建image:

docker build -t vincent/flask-redis .

我們既然要使用redis,但是我們并沒有在Dockerfile中安裝redis,只是在引入了一個(gè)Python redis依賴庫(kù),如何使用redis服務(wù)?

當(dāng)我們build一個(gè)復(fù)雜的App的時(shí)候,我們需要把App的組件分成不同的容器去部署。我們把redis作為一個(gè)單獨(dú)的App進(jìn)行部署,flask作為一個(gè)單獨(dú)的App進(jìn)行部署,flask要去訪問redis。我們先創(chuàng)建一個(gè)redis的一個(gè)容器。

docker run -d --name redis redis
docker container ls
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
1fb5745864cd        redis               "docker-entrypoint.s…"   23 seconds ago      Up 22 seconds       6379/tcp            redis

但是我們現(xiàn)在的redis的端口是6379。但是我們?cè)趧?chuàng)建容器的時(shí)候,并沒有指定-p 6379:6379 參數(shù)。

問什么呢?因?yàn)槲覀冞@里的redis不是提供給外面的人訪問的,他是供我們App內(nèi)部訪問的,因此我們沒必要把6379暴露到外面去(這樣不安全)。

此外我們的App.py并不知道redis的IP地址,因此把地址用環(huán)境變量的方式獲?。╫s.environ.get('REDIS_HOST', '127.0.0.1'))。

我們可以使用link參數(shù),通過訪問redis的容器名字來(lái)訪問。

創(chuàng)建flask-redis的container:

docker run -d --link redis --name flask-redis -e REDIS_HOST=redis vincent/flask-redis

-e REDIS_HOST 表示在當(dāng)前容器vincent/flask-redis中設(shè)置一個(gè)環(huán)境變量REDIS_HOST=redis

我們進(jìn)入到容器中查看env:

docker exec -it flask-redis /bin/bash
root@45977ae3cbed:/app# env
REDIS_PORT_6379_TCP_PROTO=tcp
REDIS_PORT=tcp://172.17.0.2:6379
REDIS_NAME=/flask-redis/redis
LANG=C.UTF-8
HOSTNAME=45977ae3cbed
REDIS_PORT_6379_TCP_ADDR=172.17.0.2
REDIS_PORT_6379_TCP=tcp://172.17.0.2:6379
GPG_KEY=C01E1CAD5EA2C4F0B8E3571504C367C218ADD4FF
PYTHONIOENCODING=UTF-8
REDIS_ENV_REDIS_DOWNLOAD_URL=http://download.redis.io/releases/redis-5.0.5.tar.gz
REDIS_HOST=redis
PWD=/app
HOME=/root
REDIS_PORT_6379_TCP_PORT=6379
TERM=xterm
REDIS_ENV_REDIS_DOWNLOAD_SHA=2139009799d21d8ff94fc40b7f36ac46699b9e1254086299f8d3b223ca54a375
REDIS_ENV_GOSU_VERSION=1.10
PYTHON_VERSION=2.7.16
SHLVL=1
PATH=/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
REDIS_ENV_REDIS_VERSION=5.0.5
PYTHON_PIP_VERSION=19.1.1
_=/usr/bin/env

可以看到里面有一個(gè)環(huán)境變量REDIS_HOST=redis

通過name來(lái)ping通:

root@45977ae3cbed:/app# ping redis
PING redis (172.17.0.2) 56(84) bytes of data.
64 bytes from redis (172.17.0.2): icmp_seq=1 ttl=64 time=1.16 ms
64 bytes from redis (172.17.0.2): icmp_seq=2 ttl=64 time=0.105 ms
64 bytes from redis (172.17.0.2): icmp_seq=3 ttl=64 time=0.215 ms

可以在容器內(nèi)發(fā)送請(qǐng)求:

root@e9361b832e36:/app# curl 127.0.0.1:5000
Hello Container World! I have bean seen 3 times and my hostname is e9361b832e36.
root@e9361b832e36:/app# curl 127.0.0.1:5000
Hello Container World! I have bean seen 4 times and my hostname is e9361b832e36.
root@e9361b832e36:/app# curl 127.0.0.1:5000
Hello Container World! I have bean seen 5 times and my hostname is e9361b832e36.

但是這時(shí)候在宿主機(jī)中還是無(wú)法訪問。

我們重新啟動(dòng)flask-redis服務(wù),并指定端口:

docker run  -d -p 5000:5000 --link redis --name flask-redis -e REDIS_HOST=redis vincent/flask-redis
docker container ls
CONTAINER ID        IMAGE                 COMMAND                  CREATED             STATUS              PORTS                    NAMES
835a7fb5a689        vincent/flask-redis   "python app.py"          2 minutes ago       Up 4 seconds        0.0.0.0:5000->5000/tcp   flask-redis
1fb5745864cd        redis                 "docker-entrypoint.s…"   15 hours ago        Up 40 seconds       6379/tcp                 redis

在宿主機(jī)中訪問:

curl 127.0.0.1:5000
Hello Container World! I have bean seen 8 times and my hostname is 835a7fb5a689.

感謝各位的閱讀,以上就是“docker中怎么擴(kuò)展Python程序”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)docker中怎么擴(kuò)展Python程序這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI