摘要:前言本文主要內容關于使用實踐部署后端和前端應用。記錄其中遇到的一些坑以及解決辦法。只能使用麻煩點的寫法在每個的設置項里重復映射主機的文件不同容器互相通信使用實現容器間通信。容器啟動順序實現容器按順序啟動,需要用到。
前言
本文主要內容關于使用docker-compose實踐部署后端django-rest-framework和前端vue.js應用。記錄其中遇到的一些坑以及解決辦法。
準備Docker-compose環境系統:Ubuntu 16.04(阿里云)
代碼中用戶名:test
# install docker ## prepare echo "Preparing..." sudo apt update sudo apt upgrade -y sudo apt install -y linux-image-extra-$(uname -r) linux-image-extra-virtual ## docker echo "Installing docker..." sudo apt remove -y docker-ce docker-engine docker.io wget -qO- http://acs-public-mirror.oss-cn-hangzhou.aliyuncs.com/docker-engine/internet | sh sudo apt autoremove -y sudo usermod -aG docker ${USER} ## docker Aliyun accelerator ## https://cr.console.aliyun.com/#/accelerator echo "Configuring docker registry mirrors..." sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json <<-"EOF" { "registry-mirrors": ["https://部署 目錄結構.mirror.aliyuncs.com"] } EOF exists(){ command -v "$1" >/dev/null 2>&1 } echo "Installing docker-compose..." if ! exists pip; then sudo apt install python-pip fi sudo python `which pip` install docker-compose echo "Restarting docker..." sudo systemctl daemon-reload sudo systemctl restart docker
. ├── .env // 環境變量 ├── docker-compose.yml ├── backend // 放置后臺django文件 ├── frontend // 放置前端vue編譯后代碼 └── nginx // nginx相關配置 ├── backend.conf ├── Dockerfile └── frontend.conf具體配置 docker-compose.yml
version: "3" services: web: restart: always build: ./backend expose: - "8000" volumes: - ./backend:/code env_file: .env links: - db depends_on: - db command: ["/code/wait-for-it.sh", "db:3306", "--", "bash","startup.sh"] nginx: restart: always build: ./nginx ports: - "80:80" volumes: - ./frontend:/usr/share/nginx/html/frontend:ro - ./backend/public:/usr/share/nginx//html/backend/public:ro links: - web depends_on: - web db: restart: always image: mysql:latest env_file: .env volumes: - ./data/initsql:/docker-entrypoint-initdb.d - ./data/db:/var/lib/mysql command: [mysqld, --character-set-server=utf8, --collation-server=utf8_unicode_ci]
第一次使用docker-compose部署,從網上參考了許多例子。但是由于docker-compose個版本的語法改動不小,遇到很多坑:
不同容器共享數據(host主機上的數據)不同容器互相通信有些例子使用volumes_from,但是version 3已經刪除該設置項更新變化。
官方推薦在根節點(與services同級)下配置volumes,但是沒法映射到host主機的文件,有個插件local-persist可以做到,但是不想依賴第三方插件。只能使用麻煩點的寫法:在每個service的volume設置項里重復映射host主機的文件web: volumes: - ./backend:/code nginx: volumes: - ./backend/public:/usr/share/nginx//html/backend/public:ro
使用links實現容器間通信。配置需要訪問的容器于links配置項下,沒什么毛病。容器啟動順序
環境變量實現容器按順序啟動,需要用到depends_on。
但是會有一個問題:depends_on只保證啟動順序,而我們的實際需求是:web容器啟動的commands必須等到mysql完全啟動,web容器的command才可以執行。因為我們加了restart: always,所以會導致web容器不斷重啟直到db容器啟動完成。
我的解決辦法是:給web容器的啟動命令加上對mysql服務可用的查詢,使用了一個查詢腳本wait-for-it:
command: ["/code/wait-for-it.sh", "db:3306", "--", "bash","startup.sh"]
關于Mysql官方鏡像配置會有多個容器使用相同環境變量的情況,所以都放在.env文件里
DEBUG=false MYSQL_HOST=db MYSQL_DATABASE=mydb MYSQL_ROOT_PASSWORD=mypass
關于Nginx容器配置
可以定義volume持久化數據庫文件:
volumes:- 如果有初始數據需要導入,可以定義volume映射到`/docker-entrypoint-initdb.d`:volumes:
- ./data/initsql:/docker-entrypoint-initdb.d注意: 該配置只有在`/var/lib/mysql/`下的`mysql`目錄不存在時才會生效。也就是說,一旦容器啟動過一次,之后就在也不會導入`/docker-entrypoint-initdb.d`里的文件,除非手動清空`/var/lib/mysql/`(或host主機的`./data/db`目錄)。
關于django web容器配置Dockerfile
FROM nginx:alpine RUN rm /etc/nginx/conf.d/default.conf ADD frontend.conf /etc/nginx/conf.d/ ADD backend.conf /etc/nginx/conf.d/frontend.conf - vue app build files
server { listen 80 deferred; server_name new.bylie.cn; root /usr/share/nginx/html/frontend; location / { try_files $uri $uri/ /index.html =404; } # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html; } }backend.conf - django app
server { # use "listen 80 deferred;" for Linux # use "listen 80 accept_filter=httpready;" for FreeBSD listen 80 deferred; client_max_body_size 5M; # set the correct host(s) for your site server_name service.bylie.cn; keepalive_timeout 5; location /public { root /usr/share/nginx/html/backend; } location / { proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # enable this if and only if you use HTTPS # proxy_set_header X-Forwarded-Proto https; proxy_set_header Host $http_host; # we don"t want nginx trying to do something clever with # redirects, we set the Host: header above already. proxy_redirect off; proxy_pass http://web:8000; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }備份數據庫到host主機
docker-compose exec db sh -c "exec mysqldump -uroot -p"$MYSQL_ROOT_PASSWORD" --databases ${MYSQL_DATABASE}" > ./backup/database.sql
比較簡單
Dockerfile
FROM python:3 ENV PYTHONUNBUFFERED 1 RUN mkdir /code WORKDIR /code ADD requirements.txt /tmp/ RUN pip install -r /tmp/requirements.txt啟動腳本startup.sh
#!/usr/bin/env bash python manage.py collectstatic --noinput && python manage.py migrate && gunicorn django_web_app.wsgi:application -w 2 -b :8000當容器運行起來之后,可能需要導入一些初始數據或者fixtures,我寫了一個init的django custom command,手動執行該command:
docker-compose exec web python manage.py init
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/26969.html
摘要:前言本文主要內容關于使用實踐部署后端和前端應用。記錄其中遇到的一些坑以及解決辦法。只能使用麻煩點的寫法在每個的設置項里重復映射主機的文件不同容器互相通信使用實現容器間通信。容器啟動順序實現容器按順序啟動,需要用到。 前言 本文主要內容關于使用docker-compose實踐部署后端django-rest-framework和前端vue.js應用。記錄其中遇到的一些坑以及解決辦法。 準備...
摘要:按照指示,分別安裝和,然后測試安裝結果接下來,根據以下項目結構從克隆一份項目或自己創建項目現在我們準備容器運行開啟,只需運行這個命令設置一個新的開發環境。 原文地址:Django Development With Docker Compose and Machine 以下為譯文 Docker 是一個開源的應用容器引擎,讓開發者可以打包他們的應用以及依賴包到一個可移植的容器...
摘要:創建第一個應用,第一步在構建容器原文翻譯整理這篇文章將指導你如何用配置和啟動一個簡單的應用。一詞我認為翻譯為編制更恰當。在這里我們需要一個服務器,一個數據服務器。編制文件指明了我們這些服務所用的鏡像,他們如何連接,哪些卷要掛載到容器。 Mac Docker 創建第一個Django 應用, Part 1 第一步:在Mac構建Django 容器 原文:Quickstart: Compose...
摘要:創建第一個應用,第一步在構建容器原文翻譯整理這篇文章將指導你如何用配置和啟動一個簡單的應用。一詞我認為翻譯為編制更恰當。在這里我們需要一個服務器,一個數據服務器。編制文件指明了我們這些服務所用的鏡像,他們如何連接,哪些卷要掛載到容器。 Mac Docker 創建第一個Django 應用, Part 1 第一步:在Mac構建Django 容器 原文:Quickstart: Compose...
摘要:今天整理了一下如何在中部署項目。執行可以查看容器出錯的具體原因。若上述容器都成功運行,則在瀏覽器中輸入時,視圖會返回相應的結果。以交互方式進入容器后,進入數據庫,會看到在數據庫中生成了相應的表。 今天整理了一下如何在docker中部署django項目。 1.環境如下: python3.6 django2.0.5 nginx mysql5.7 gunicorn 2.項目結構如下:...
閱讀 1211·2023-04-25 20:31
閱讀 3718·2021-10-14 09:42
閱讀 1485·2021-09-22 16:06
閱讀 2636·2021-09-10 10:50
閱讀 3524·2021-09-07 10:19
閱讀 1772·2019-08-30 15:53
閱讀 1170·2019-08-29 15:13
閱讀 2818·2019-08-29 13:20