摘要:前言拋開(kāi)那些強(qiáng)大的功能,今天我們來(lái)部署下本地的開(kāi)發(fā)環(huán)境。提升開(kāi)發(fā)效率和質(zhì)量是每位程序員必備的技能。這并不是一個(gè)非常認(rèn)真的操作,請(qǐng)勿使用到生產(chǎn)環(huán)境。
前言
拋開(kāi)Docker那些強(qiáng)大的功能,今天我們來(lái)部署下本地的開(kāi)發(fā)環(huán)境。并寫(xiě)上幾個(gè)腳本來(lái)提高開(kāi)發(fā)效率。
本章以MacOs系統(tǒng)的Docker演示,其他系統(tǒng)作者為接觸過(guò)。不知是否有差別。
安裝傻瓜式安裝,這里就不再闡述了。下載地址如下
https://www.docker.com/produc...
目錄創(chuàng)建一些目錄,就如在項(xiàng)目開(kāi)發(fā)中創(chuàng)建Controller,Model,Service一樣。我們將本地的Docker開(kāi)發(fā)環(huán)境先從目錄開(kāi)始整理以下。
目錄名 | 用途 |
---|---|
app | 項(xiàng)目目錄,源程序存放的地方 |
services | 服務(wù)目錄,例如mysql,php等 |
ssh | 遠(yuǎn)程服務(wù)器目錄,用于鏈接服務(wù)器 |
web | 前端目錄,正常node會(huì)指向它 |
部分文件列表
文件名 | 用途 |
---|---|
.env | 配置公共文件 |
docker-compose.yml | docker-composer 配置文件 |
hosts | 系統(tǒng) hosts 文件 |
php.sh | php 相關(guān)操作文件 |
start.sh | 本地環(huán)境操作腳本 |
因是個(gè)人使用,所以對(duì)命名和規(guī)范稍有出入。請(qǐng)諒解
配置服務(wù)配置你所需要的服務(wù)到Docker容器內(nèi)
MySQLdocker-composer.yml
db: container_name: "dev_db" build: ./services/mysql // 指向dockerfile文件 environment: MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD} // .env文件的配置項(xiàng) ports: - "3306:3306" volumes: - ${MYSQL_DATA_PATH}:/var/lib/mysql
創(chuàng)建mysql-dockerfile到servicesmysql
Dockerfile
FROM mysql:5.6 MAINTAINER crazycodes <[email protected]> ADD ./config/default.cnf /etc/mysql/conf.d/default.cnfNginx
docker-composer.yml
web: container_name: "dev_nginx" build: ./services/nginx ports: - "80:80" depends_on: - php volumes_from: - php volumes: - ${NGINX_VOLUME_CONFIG_PATH}:/etc/nginx/conf.d dns: 8.8.8.8
Dockerfile
FROM nginx:latest MAINTAINER crazycodes <[email protected]> RUN apt-get update && apt-get install -y vim sudo gcc make unzip wget mercurial libpcre3-dev zlib1g-dev libssl-dev devscripts debhelper dpkg-dev quilt lsb-release COPY nginx.conf /etc/nginx/nginx.conf COPY nginx-rtmp-module /etc/nginx/nginx-rtmp-module COPY nginx-1.13.9 /etc/nginx/nginx-1.13.9 WORKDIR /etc/nginx/nginx-1.13.9 RUN ./configure --prefix=/etc/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib/nginx/modules --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock --http-client-body-temp-path=/var/cache/nginx/client_temp --http-proxy-temp-path=/var/cache/nginx/proxy_temp --http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp --http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp --http-scgi-temp-path=/var/cache/nginx/scgi_temp --user=nginx --group=nginx --with-compat --with-file-aio --with-threads --with-http_addition_module --with-http_auth_request_module --with-http_dav_module --with-http_flv_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_mp4_module --with-http_random_index_module --with-http_realip_module --with-http_secure_link_module --with-http_slice_module --with-http_ssl_module --with-http_stub_status_module --with-http_sub_module --with-http_v2_module --with-mail --with-mail_ssl_module --with-stream --with-stream_realip_module --with-stream_ssl_module --with-stream_ssl_preread_module --with-cc-opt="-g -O2 -fdebug-prefix-map=/data/builder/debuild/nginx-1.13.7/debian/debuild-base/nginx-1.13.7=. -specs=/usr/share/dpkg/no-pie-compile.specs -fstack-protector-strong -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 -fPIC" --with-ld-opt="-specs=/usr/share/dpkg/no-pie-link.specs -Wl,-z,relro -Wl,-z,now -Wl,--as-needed -pie" --add-module=../nginx-rtmp-module RUN make && make install
站點(diǎn)配置在services ginxconfig內(nèi),你可以正常配置
server { listen 80; server_name localhost; root /mnt/app/flarum; index index.php index.html index.htm; location / { try_files $uri $uri/ /index.php?$query_string; } location /api { try_files $uri $uri/ /api.php?$query_string; } location /admin { try_files $uri $uri/ /admin.php?$query_string; } location /flarum { deny all; return 404; } location ~ .php$ { fastcgi_split_path_info ^(.+.php)(/.+)$; fastcgi_pass php:9000; // 容器內(nèi),此處要填 容器名稱:容器映射端口 fastcgi_index index.php; include fastcgi_params; } }PHP
dockerfile文件內(nèi)容過(guò)多。這里就不貼代碼了。文章最后會(huì)貼出源碼地址。
其他活學(xué)活用,代碼不僅僅是幫助你開(kāi)發(fā),也可以幫你提示開(kāi)發(fā)效率。將所有工作變得自動(dòng)化,更能體現(xiàn)你的本領(lǐng)。
sshssh中放著所有服務(wù)器鏈接文件
set -x ssh [email protected]
每次當(dāng)你需要鏈接服務(wù)器時(shí),直接使用
sh dev.sh
即可
php.sh如果想要操作容器內(nèi)php的命令。命令過(guò)長(zhǎng),不方便。我們可以將代碼放入sh文件中
set -x docker exec -it dev_php /bin/sh -c "cd /mnt/app/${1} && ${2}"
這時(shí)你如果需要操作容器內(nèi)的PHP,就可以這樣寫(xiě)
sh php.sh My_Blog artisan migratestart.sh
start.sh文件中存放著一些基本命令,當(dāng)然你也可以繼續(xù)擴(kuò)展你想要的。例如對(duì)composer的操作,php的操作,mysql的操作等等。具體你可以去點(diǎn)擊下方鏈接查看。
致謝習(xí)慣將許多命令封裝到執(zhí)行文件內(nèi)。方便自己使用。提升開(kāi)發(fā)效率和質(zhì)量是每位程序員必備的技能。
https://github.com/CrazyCodes...
這并不是一個(gè)非常認(rèn)真的docker“操作”,請(qǐng)勿使用到生產(chǎn)環(huán)境。
很高興你看到這里,希望本篇文章可以幫到你。謝謝。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/27463.html
摘要:前言拋開(kāi)那些強(qiáng)大的功能,今天我們來(lái)部署下本地的開(kāi)發(fā)環(huán)境。提升開(kāi)發(fā)效率和質(zhì)量是每位程序員必備的技能。這并不是一個(gè)非常認(rèn)真的操作,請(qǐng)勿使用到生產(chǎn)環(huán)境。 showImg(https://segmentfault.com/img/bVbg72t?w=800&h=528); 前言 拋開(kāi)Docker那些強(qiáng)大的功能,今天我們來(lái)部署下本地的開(kāi)發(fā)環(huán)境。并寫(xiě)上幾個(gè)腳本來(lái)提高開(kāi)發(fā)效率。 本章以MacOs系統(tǒng)...
摘要:回滾部署開(kāi)發(fā)者每次部署的程序包會(huì)自動(dòng)備份到歷史版本,發(fā)布異常時(shí),可以指定回滾部署到某一歷史版本。網(wǎng)絡(luò)方面采用了硬件防火墻設(shè)施,提供四層到七層的全面防護(hù),防護(hù)類型包括等所有攻擊方式,支持清洗和黑洞機(jī)制,還接入了防護(hù)等功能。 TAE2.0(Taobao App Engine)是針對(duì)移動(dòng)互聯(lián)網(wǎng)場(chǎng)景的定制化PaaS云服務(wù),基于阿里云基礎(chǔ)設(shè)施,采用Docker容器技術(shù)封裝應(yīng)用運(yùn)行環(huán)境,并且針對(duì)互...
摘要:回滾部署開(kāi)發(fā)者每次部署的程序包會(huì)自動(dòng)備份到歷史版本,發(fā)布異常時(shí),可以指定回滾部署到某一歷史版本。網(wǎng)絡(luò)方面采用了硬件防火墻設(shè)施,提供四層到七層的全面防護(hù),防護(hù)類型包括等所有攻擊方式,支持清洗和黑洞機(jī)制,還接入了防護(hù)等功能。 TAE2.0(Taobao App Engine)是針對(duì)移動(dòng)互聯(lián)網(wǎng)場(chǎng)景的定制化PaaS云服務(wù),基于阿里云基礎(chǔ)設(shè)施,采用Docker容器技術(shù)封裝應(yīng)用運(yùn)行環(huán)境,并且針對(duì)互...
閱讀 4627·2021-09-26 09:55
閱讀 1369·2019-12-27 12:16
閱讀 890·2019-08-30 15:56
閱讀 1908·2019-08-30 14:05
閱讀 995·2019-08-30 13:05
閱讀 1271·2019-08-30 10:59
閱讀 1447·2019-08-26 16:19
閱讀 1889·2019-08-26 13:47