一、環境html
二、安裝dockermysql
首先查看CentOS的內核版本(CentOS7系統必須爲64位,內核必須3.10及以上)react
uname -r 3.10.0-229.el7.x86_64
更新已經安裝的包linux
sudo yum update
安裝dockergit
curl -fsSL https://get.docker.com/ | sh
啓動dockergithub
sudo service docker start 或 systemctl start docker
運行docker hello world demoweb
sudo docker run hello-world
三、建立docker用戶組sql
(2) sudo usermod -aG docker
your_username(你的用戶名)
四、 docker相關概念docker
-P
或 -p
參數來指定端口映射。
docker images //顯示全部鏡像文件 docker ps -q -a //顯示全部容器 docker run -it --name dn_container -d -p 5000:5000 microsoft/dotnet:latest //新增一個容器用於加載 microsoft/dotnet:latest鏡像文件,-p host port:container port docker run -it --name dn_container -d -p 127.0.0.1:5000:5000 microsoft/dotnet:latest docker start dn_container //啓動容器 docker attach dn_container //關聯並進入啓動容器,須要先啓動容器 docker stop dn_container //中止容器 docker kill $(docker ps -a -q) //強制中止全部容器 docker rm $(docker ps -a -q) //刪除全部容器 doker commit ContainerID NewImageName //將容器裏的內容提交爲新的鏡像文件 docker rmi -f 7d9495d03763 //刪除全部容器 //標記鏡像,push到Docker Hub docker images docker tag a66b7258f574 sobit17/sobit-dotnet:1.0.0-beta-002252 docker images docker login --username=test --email=test@qq.com docker push sobit17/sobit-dotnet
五、製做HelloMvc imagecanvas
mkdir app cd app git clone https://github.com/aspnet/cli-samples.git cd cli-samples
須要顯式指定HelloMvc的端口(即便指定的是5000端口),目前嘗試過不加下面這段代碼,發現默認的5000並不起做用
//拷貝命令 cp -p /root/app/cli-samples/NuGet.Config /root/app/cli-samples/HelloMvc/NuGet.Config
FROM microsoft/dotnet:latest RUN mkdir -p /webapp COPY . /webapp WORKDIR /webapp RUN ["dotnet", "restore"] RUN sudo apt-get -y update \ && sudo apt-get install -y dialog make automake libtool curl RUN curl -sSL https://github.com/libuv/libuv/archive/v1.8.0.tar.gz | sudo tar zxfv - -C /usr/local/src \ && cd /usr/local/src/libuv-1.8.0 \ && sudo sh autogen.sh \ && sudo ./configure \ && sudo make \ && sudo make install \ && sudo rm -rf /usr/local/src/libuv-1.8.0 \ && cd ~/ \ && sudo ldconfig EXPOSE 5600 ENTRYPOINT ["dotnet", "run"]
(2)基於dotnet:0.0.1-alpha-onbuild
FROM microsoft/dotnet:0.0.1-alpha-onbuild RUN sudo apt-get -y update \ && sudo apt-get install -y dialog make automake libtool curl RUN curl -sSL https://github.com/libuv/libuv/archive/v1.8.0.tar.gz | sudo tar zxfv - -C /usr/local/src \ && cd /usr/local/src/libuv-1.8.0 \ && sudo sh autogen.sh \ && sudo ./configure \ && sudo make \ && sudo make install \ && sudo rm -rf /usr/local/src/libuv-1.8.0 \ && cd ~/ \ && sudo ldconfig EXPOSE 5600
mkdir test cd test it clone https://github.com/aspnet/cli-samples.git cd cli-samples dotnet restore
查看是否報錯
cd ~rm -r test
(2)解決方案
docker run --name dotnet_container -it microsoft/dotnet:0.0.1-alpha
若是dotnet_container 未啓動,則執行下面命令啓動並關聯進入
docker start dotnet_container
dokcer attach dotnet_container
查看.NET Core版本(dotnet image中使用的是Ubuntu14.04系統)
dotnet --version 或 dotnet --info
apt-get update wget https://dotnetcli.blob.core.windows.net/dotnet/beta/Binaries/Latest/dotnet-dev-ubuntu-x64.latest.tar.gz tar -zxf dotnet-dev-ubuntu-x64.latest.tar.gz -C /usr/bin
或
apt-get update wget https://dotnetcli.blob.core.windows.net/dotnet/beta/Binaries/Latest/dotnet-dev-ubuntu-x64.latest.tar.gz tar -zxf dotnet-dev-ubuntu-x64.latest.tar.gz ln -s /dn_new/dotnet /usr/bin/dotnet
接下來執行下面命令
dotnet --info //查看版本 exit //退出容器 docker images //查找dotnet_container 的ConrainerID docker commit 3a09b2588478(ContainerID) dotnet_new(new image name) //commit成一個新的image
至此base image製做完畢。
FROM dotnet_new 或 sobit17/sobit-dotnet:1.0.0-beta-002252 RUN mkdir -p /webapp COPY . /webapp WORKDIR /webapp RUN ["dotnet", "restore"] ##備註:安裝libuv這一過程其實能夠在製做dotnet_new鏡像時也安裝進去,就不須要下面這段【註釋在Dockerfile中需刪掉】 RUN sudo apt-get -y update \ && sudo apt-get install -y dialog make automake libtool curl RUN curl -sSL https://github.com/libuv/libuv/archive/v1.8.0.tar.gz | sudo tar zxfv - -C /usr/local/src \ && cd /usr/local/src/libuv-1.8.0 \ && sudo sh autogen.sh \ && sudo ./configure \ && sudo make \ && sudo make install \ && sudo rm -rf /usr/local/src/libuv-1.8.0 \ && cd ~/ \ && sudo ldconfig EXPOSE 5600 ENTRYPOINT ["dotnet", "run"]
全部把HelloMvc製做成image的資料已經準備完畢。
docker build -t hellomvc-image . //記得命令最後有'.'
一、環境
二、安裝.NET Core SDK
sudo yum updatemkdir dn_cli cd dn_cli wget https://dotnetcli.blob.core.windows.net/dotnet/beta/Binaries/Latest/dotnet-dev-centos-x64.latest.tar.gz tar -zxf dotnet-dev-centos-x64.latest.tar.gz
嘗試執行命令:. /dotnet
提示錯誤:
Failed to load /root/dotnet/bin/libcoreclr.so, error: libunwind.so.8: cannot open shared object file: No such file or directory
解決方法:
yum install -y libunwind
嘗試執行命令:. /dotnet
提示錯誤:
Failed to initialize CoreCLR, HRESULT: 0x80131500
解決方法:
yum install -y icu
嘗試執行命令:. /dotnet --info,正常。
永久保存環境變量
找到/etc/profile文件(當用戶第一次登陸時,該文件被執行.),在最後面添加:
3、下載cli-samples的HelloMvc例子
cd ~
sudo yum -y install git mkdir app cd app git clone https://github.com/aspnet/cli-samples.git cd cli-samples dotnet restore cd HelloMvc
須要顯式指定HelloMvc的端口(即便指定的是5000端口),目前嘗試過不加下面這段代碼,發現默認的5000並不起做用
四、編譯運行HelloMvc
將執行命令的當前目錄定位到HelloMvc,並執行下面命令
dotnet run
打開瀏覽器 http://IP:5600(防火牆和查看網絡相關命令請查看本篇文章第四點)
一、安裝Ubuntu Installers
apt-get update
mkdir dn_cli cd dn_cli wget https://dotnetcli.blob.core.windows.net/dotnet/beta/Installers/Latest/dotnet-host-ubuntu-x64.latest.deb wget https://dotnetcli.blob.core.windows.net/dotnet/beta/Installers/Latest/dotnet-sharedframework-ubuntu-x64.latest.deb wget https://dotnetcli.blob.core.windows.net/dotnet/beta/Installers/Latest/dotnet-sdk-ubuntu-x64.latest.deb //安裝 dpkg -i dotnet-host-ubuntu-x64.latest.deb dpkg -i dotnet-sharedframework-ubuntu-x64.latest.deb dpkg -i dotnet-sdk-ubuntu-x64.latest.deb
//若是執行上述安裝語句後提示缺乏依賴包,能夠執行下面命令會自動補全依賴包,而後再從新執行報錯的安裝語句
apt-get -f install
2、下載cli-samples的HelloMvc例子
cd ~
apt-get -y install git mkdir app cd app git clone https://github.com/aspnet/cli-samples.git cd cli-samples dotnet restore cd HelloMvc
須要顯式指定HelloMvc的端口(即便指定的是5000端口),目前嘗試過不加下面這段代碼,發現默認的5000並不起做用
三、編譯運行HelloMvc
dotnet run
打開瀏覽器 http://IP:5600(防火牆和查看網絡相關命令請查看本篇文章第四點)
systemctl status firewalld或firewalld.service ##查看firewalld是否啓動。active(running)表明啓動
systemctl start firewalld ##若是firewalld沒啓動,可使用此命令啓動
systemctl enable firewalld ##設置爲隨機器啓動
systemctl stop firewalld ##關閉firewalld
systemctl disable firewalld ##清除隨機器啓動
systemctl restart firewalld ##重啓firewalld
firewall-cmd --state ##查看防火牆狀態,是不是running firewall-cmd --list-all ##查看全部規則 firewall-cmd --reload ##從新載入配置,好比添加規則以後,須要執行此命令 firewall-cmd --get-zones ##列出支持的zone firewall-cmd --get-services##列出支持的服務,在列表中的服務是放行的 firewall-cmd --query-service ftp##查看ftp服務是否支持,返回yes或者no firewall-cmd --add-service=ftp ##臨時開放ftp服務 firewall-cmd --add-service=ftp --permanent##永久開放ftp服務 firewall-cmd --add-service=http --permanent##永久開放http服務 firewall-cmd --remove-service=ftp --permanent##永久移除ftp服務 firewall-cmd --add-port=80/tcp --permanent ##永久添加80端口 firewall-cmd --zone=public --add-port=80/tcp --permanent ##--zone #做用域
iptables -L -n --line-number #查看防火牆的規則鏈 iptables -I INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT iptables -I INPUT -p tcp --dport 80 -m state --state NEW -j ACCEPT iptables -I INPUT -d 172.16.100.1 -p tcp --dport 22 -m state --state NEW -j ACCEPT iptables -A INPUT -i lo -j ACCEPT #測試不加此條會致使mysql在內部沒法鏈接 查看/etc/sysconfig/iptables文件(記錄着防火牆的規則鏈) 若是沒有這個文件,請執行下面命令保存 iptables-save > /etc/sysconfig/iptables 查看保存後的規則 cat /etc/sysconfig/iptables
四、部分網絡端口查詢命令
netstat -tunlp -a # 查看全部網絡端口狀況 netstat -l -n #查看監聽(Listen)的端口,-n 表明顯示端口數字而不是名稱 netstat -antp #查看全部創建的TCP鏈接
相關資料:
做者:B.it
技術收錄網站:核心技術(http://www.coretn.cn)
出處:http://www.cnblogs.com/ImBit/p/5375577.html
本文版權歸做者和博客園共有,歡迎轉載,但未經做者贊成必須保留此段聲明,且在文章頁面明顯位置給出原文鏈接。