1.創建文件夾保存jar和Dockerfile文件

2.編輯Dockerfile
#網上拖取java8的鏡像 FROM java:8 #作者信息 MAINTAINER 1650772084 #添加本地的jar包到根目錄 ADD ROOT.jar web.jar #暴露jar運行的端口 EXPOSE 88/tcp #執行cmd命令,下面兩種方式都可以 ENTRYPOINT ["java","-Duser.timezone=GMT+08","-jar","/web.jar"]
3.執行build
docker build -t web .
.是當前目錄 不要忽略了
3.1 docker build 命令用於使用 Dockerfile 創建鏡像。
docker build典型用法
docker build -t ImageName:TagName dir
選項
-
-t− 給鏡像加一個Tag -
ImageName− 給鏡像起的名稱 -
TagName− 給鏡像的Tag名 -
Dir− Dockerfile所在目錄
4.運行容器
docker run -d --restart=always --name web -p 8080:8080 web
最基本的docker run命令的格式如下:
docker run [OPTIONS] IMAGE[:TAG] [COMMAND] [ARG...]
Usage: Run a command in a new container
中文意思為:通過run命令創建一個新的容器(container)
常用選項說明: -d, --detach=false, 指定容器運行於前台還是后台,默認為false -i, --interactive=false, 打開STDIN,用於控制台交互 -t, --tty=false, 分配tty設備,該可以支持終端登錄,默認為false -u, --user="", 指定容器的用戶 -a, --attach=[], 登錄容器(必須是以docker run -d啟動的容器) -w, --workdir="", 指定容器的工作目錄 -c, --cpu-shares=0, 設置容器CPU權重,在CPU共享場景使用 -e, --env=[], 指定環境變量,容器中可以使用該環境變量 -m, --memory="", 指定容器的內存上限 -P, --publish-all=false, 指定容器暴露的端口 -p, --publish=[], 指定容器暴露的端口 -h, --hostname="", 指定容器的主機名 -v, --volume=[], 給容器掛載存儲卷,掛載到容器的某個目錄 --volumes-from=[], 給容器掛載其他容器上的卷,掛載到容器的某個目錄 --cap-add=[], 添加權限,權限清單詳見:http://linux.die.net/man/7/ca... --cap-drop=[], 刪除權限,權限清單詳見:http://linux.die.net/man/7/ca... --cidfile="", 運行容器后,在指定文件中寫入容器PID值,一種典型的監控系統用法 --cpuset="", 設置容器可以使用哪些CPU,此參數可以用來容器獨占CPU --device=[], 添加主機設備給容器,相當於設備直通 --dns=[], 指定容器的dns服務器 --dns-search=[], 指定容器的dns搜索域名,寫入到容器的/etc/resolv.conf文件 --entrypoint="", 覆蓋image的入口點 --env-file=[], 指定環境變量文件,文件格式為每行一個環境變量 --expose=[], 指定容器暴露的端口,即修改鏡像的暴露端口 --link=[], 指定容器間的關聯,使用其他容器的IP、env等信息 --lxc-conf=[], 指定容器的配置文件,只有在指定--exec-drive --name="", 指定容器名字,后續可以通過名字進行容器管理,links特性需要使用名字
--privileged=false, 指定容器是否為特權容器,特權容器擁有所有的capabilities
--restart="no", 指定容器停止后的重啟策略:
no:容器退出時不重啟
on-failure:容器故障退出(返回值非零)時重啟
always:容器退出時總是重啟
--rm=false, 指定容器停止后自動刪除容器(不支持以docker run -d啟動的容器)
--sig-proxy=true, 設置由代理接受並處理信號,但是SIGCHLD、SIGSTOP和SIGKILL不能被代理
