私人网站建设白云区网站建设

web/2025/10/1 17:46:37/文章来源:
私人网站建设,白云区网站建设,百度网站提交了多久收录,做原型的素材网站Docker 1.什么是 Docker 官网的介绍是“Docker is the world’s leading software container platform.” 官方给Docker的定位是一个应用容器平台。 Docker 是一个容器平台的领导者 Docker 容器平台 Docker 应用容器平台 application项目 Mysql Redis MongoDB ElasticSeacrh …Docker 1.什么是 Docker 官网的介绍是“Docker is the world’s leading software container platform.” 官方给Docker的定位是一个应用容器平台。 Docker 是一个容器平台的领导者 Docker 容器平台 Docker 应用容器平台 application项目 Mysql Redis MongoDB ElasticSeacrh … application项目 Docker 应用容器平台 Mysql Redis mongoDB ElasticSearch tomcat nginx… 2.为什么是Docker 合作开发的时候在本机可以跑别人的电脑跑不起来 这里我们拿java Web应用程序举例我们一个java Web应用程序涉及很多东西比如jdk、tomcat、spring等等。当这些其中某一项版本不一致的时候可能就会导致应用程序跑不起来这种情况。Docker则将程序直接打包成镜像直接运行在容器中即可。 服务器自己的程序挂了结果发现是别人程序出了问题把内存吃完了自己程序因为内存不够就挂了 这种也是一种比较常见的情况如果你的程序重要性不是特别高的话公司基本上不可能让你的程序独享一台服务器的这时候你的服务器就会跟公司其他人的程序共享一台服务器所以不可避免地就会受到其他程序的干扰导致自己的程序出现问题。Docker就很好解决了环境隔离的问题别人程序不会影响到自己的程序。 公司要弄一个活动可能会有大量的流量进来公司需要再多部署几十台服务器 在没有Docker的情况下要在几天内部署几十台服务器这对运维来说是一件非常折磨人的事而且每台服务器的环境还不一定一样就会出现各种问题最后部署地头皮发麻。用Docker的话我只需要将程序打包到镜像你要多少台服务我就给力跑多少容器极大地提高了部署效率。 3.Docker和虚拟机区别 关于Docker与虚拟机的区别我在网上找到的一张图非常直观形象地展示出来话不多说直接上图。 比较上面两张图我们发现虚拟机是携带操作系统本身很小的应用程序却因为携带了操作系统而变得非常大很笨重。Docker是不携带操作系统的所以Docker的应用就非常的轻巧。另外在调用宿主机的CPU、磁盘等等这些资源的时候拿内存举例虚拟机是利用Hypervisor去虚拟化内存整个调用过程是虚拟内存-虚拟物理内存-真正物理内存但是Docker是利用Docker Engine去调用宿主的的资源这时候过程是虚拟内存-真正物理内存。 传统虚拟机Docker容器磁盘占用几个GB到几十个GB左右几十MB到几百MB左右CPU内存占用虚拟操作系统非常占用CPU和内存Docker引擎占用极低启动速度从开机到运行项目几分钟从开启容器到运行项目几秒安装管理需要专门的运维技术安装、管理方便应用部署每次部署都费时费力从第二次部署开始轻松简捷耦合性多个应用服务安装到一起容易互相影响每个应用服务一个容器达成隔离系统依赖无需求相同或相似的内核目前推荐是Linux 4.Docker 的核心 镜像: 一个镜像代表一个应用环境,他是一个只读的文件,如 mysql镜像,tomcat镜像,nginx镜像等容器: 镜像每次运行之后就是产生一个容器,就是正在运行的镜像,特点就是可读可写仓库:用来存放镜像的位置,类似于maven仓库,也是镜像下载和上传的位置dockerFile:docker生成镜像配置文件,用来书写自定义镜像的一些配置tar:一个对镜像打包的文件,日后可以还原成镜像 4.Docker的安装(centos7.x) 5.1 卸载原有 docker $ sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine5.2 安装docker 安装docker依赖 $ sudo yum install -y yum-utils \device-mapper-persistent-data \lvm2设置docker的yum源 $ sudo yum-config-manager \--add-repo \https://download.docker.com/linux/centos/docker-ce.repo安装最新版的docker $ sudo yum install docker-ce docker-ce-cli containerd.io指定版本安装docker $ yum list docker-ce --showduplicates | sort -r $ sudo yum install docker-ce-VERSION_STRING docker-ce-cli-VERSION_STRING containerd.io $ sudo yum install docker-ce-18.09.5-3.el7 docker-ce-cli-18.09.5-3.el7 containerd.io启动docker $ sudo systemctl start docker查看docker安装状态 $ sudo systemctl status docker关闭docker $ sudo systemctl stop docker测试docker安装 $ sudo docker run hello-world6. Docker 配置阿里镜像加速服务 6.1 docker 运行流程 6.2 docker配置阿里云镜像加速 访问阿里云登录自己账号查看docker镜像加速服务 sudo mkdir -p /etc/docker sudo tee /etc/docker/daemon.json -EOF {registry-mirrors: [https://lz2nib3q.mirror.aliyuncs.com] } EOF 查看是否安装成功 sudo cat /etc/docker/daemon.json重启docker服务和进程 sudo systemctl daemon-reload sudo systemctl restart docker验证docker的镜像加速是否生效 [rootlocalhost ~]# docker info..........127.0.0.0/8Registry Mirrors:https://2t1oesp4.mirror.aliyuncs.com/Live Restore Enabled: falseProduct License: Community Engine7.Docker的入门应用 7.1 docker 的第一个程序 docker run hello-world [rootlocalhost ~]# docker run hello-worldHello from Docker! This message shows that your installation appears to be working correctly.To generate this message, Docker took the following steps:1. The Docker client contacted the Docker daemon.2. The Docker daemon pulled the hello-world image from the Docker Hub.(amd64)3. The Docker daemon created a new container from that image which runs theexecutable that produces the output you are currently reading.4. The Docker daemon streamed that output to the Docker client, which sent itto your terminal.To try something more ambitious, you can run an Ubuntu container with:$ docker run -it ubuntu bashShare images, automate workflows, and more with a free Docker ID:https://hub.docker.com/For more examples and ideas, visit:https://docs.docker.com/get-started/8.常用命令 6.1 辅助命令 # 1.安装完成辅助命令docker version -------------------------- 查看docker的信息docker info -------------------------- 查看更详细的信息docker --help -------------------------- 帮助命令6.2 Images 镜像命令 # 1.查看本机中所有镜像docker images -------------------------- 列出本地所有镜像-a 列出所有镜像包含中间映像层-q 只显示镜像id# 2.搜索镜像docker search [options] 镜像名 ------------------- 去dockerhub上查询当前镜像-s 指定值 列出收藏数不少于指定值的镜像--no-trunc 显示完整的镜像信息# 3.从仓库下载镜像docker pull 镜像名[:TAG|DIGEST] ----------------- 下载镜像# 4.删除镜像docker rmi 镜像名 -------------------------- 删除镜像-f 强制删除查看容器中服务启动日志 6.3 Contrainer 容器命令 6.3.1 基本命令(容器外操作) # 1.运行容器docker run 镜像名 -------------------------- 镜像名新建并启动容器--name 别名为容器起一个名字-d 启动守护式容器在后台启动容器-p 映射端口号原始端口号 指定端口号启动例docker run -it --name myTomcat -p 8888:8080 tomcatdocker run -d --name myTomcat -P tomcat# 2.查看运行的容器docker ps -------------------------- 列出所有正在运行的容器-a 正在运行的和历史运行过的容器-q 静默模式只显示容器编号# 3.停止|关闭|重启容器docker start 容器名字或者容器id --------------- 开启容器docker restart 容器名或者容器id --------------- 重启容器docker stop 容器名或者容器id ------------------ 正常停止容器运行docker kill 容器名或者容器id ------------------ 立即停止容器运行# 4.删除容器docker rm -f 容器id和容器名 docker rm -f $(docker ps -aq) -------------------------- 删除所有容器# 5.查看容器内进程docker top 容器id或者容器名 ------------------ 查看容器内的进程# 6.查看查看容器内部细节docker inspect 容器id ------------------ 查看容器内部细节# 7.查看容器的运行日志docker logs [OPTIONS] 容器id或容器名 ------------------ 查看容器日志-t 加入时间戳-f 跟随最新的日志打印--tail 数字 显示最后多少条 6.3.2 进阶命令(容器内数据交互) centos ---- docker(引擎) ---- mynginx(容器) # 1.进入容器内部docker exec [options] 容器id 容器内命令 ------------------ 进入容器执行命令-i 以交互模式运行容器通常与-t一起使用-t 分配一个伪终端 shell窗口 /bin/bash # 2.容器内安装软件apt-get updateapt-get install 安装包名称# 3.修改容器内文件# 4.退出容器exit 退出容器# 5.将容器打包为新的镜像docker commit -a作者 -m描述信息 容器ID 目标镜像名称:TAG# 6.从容器中复制文件到宿主机目录中docker cp 容器id:容器内资源路径 宿主机目录路径 ----------------- 将容器内资源拷贝到主机上# 7.设置容器和宿主机共享目录docker run -it -v /宿主机的路径:/容器内的路径:ro(只读) 镜像名注意: 宿主机路径必须是绝对路径,宿主机目录会覆盖容器内目录内容 运行 docker inspect 容器id 命令 检查json串里有没有以下内容如果有则证明卷挂载成功。Mounts: [{Type: bind,Source: /hostDataValueme,Destination: /containerDataValueme,Mode: ,RW: true,Propagation: rprivate}]# 8.打包镜像docker save 镜像名 -o 名称.tar # 9.载入镜像docker load -i 名称.tar7.docker的镜像原理 7.1 镜像是什么 镜像是一种轻量级的可执行的独立软件包用来打包软件运行环境和基于运行环境开发的软件它包含运行某个软件所需的所有内容包括代码、运行时所需的库、环境变量和配置文件。 7.2 为什么一个镜像会那么大 镜像就是花卷 UnionFS联合文件系统: Union文件系统是一种分层轻量级并且高性能的文件系统它支持对文件系统的修改作为一次提交来一层层的叠加同时可以将不同目录挂载到同一个虚拟文件系统下。Union文件系统是Docker镜像的基础。这种文件系统特性:就是一次同时加载多个文件系统但从外面看起来只能看到一个文件系统联合加载会把各层文件系统叠加起来这样最终的文件系统会包含所有底层的文件和目录 。 7.3 Docker镜像原理 docker的镜像实际是由一层一层的文件系统组成。 bootfsboot file system主要包含bootloader和kernelbootloader主要是引导加载kernelLinux刚启动时会加载bootfs文件系统。在docker镜像的最底层就是bootfs。这一层与Linux/Unix 系统是一样的包含boot加载器bootloader和内核kernel。当boot加载完,后整个内核就都在内存中了此时内存的使用权已由bootfs转交给内核此时会卸载bootfs。 rootfsroot file system在bootfs之上包含的就是典型的linux系统中的/dev/proc/bin/etc等标准的目录和文件。rootfs就是各种不同的操作系统发行版比如Ubuntu/CentOS等等。 我们平时安装进虚拟机的centos都有1到几个GB为什么docker这里才200MB对于一个精简的OSrootfs可以很小只需要包括最基本的命令工具和程序库就可以了因为底层直接使用Host的Kernal自己只需要提供rootfs就行了。由此可见不同的linux发行版他们的bootfs是一致的rootfs会有差别。因此不同的发行版可以共用bootfs。 7.4 为什么docker镜像要采用这种分层结构呢? 最大的一个好处就是资源共享 比如有多个镜像都是从相同的base镜像构建而来的那么宿主机只需在磁盘中保存一份base镜像。同时内存中也只需要加载一份base镜像就可以为所有容器服务了。而且镜像的每一层都可以被共享。Docker镜像都是只读的。当容器启动时一个新的可写层被加载到镜像的顶部。这一层通常被称为容器层容器层之下都叫镜像层。 8.Docker安装常用服务 8.1 安装mysql # 1.拉取mysql镜像到本地docker pull mysql:tag (tag不加默认最新版本)# 2.运行mysql服务docker run --name mysql -e MYSQL_ROOT_PASSWORDroot -d mysql:tag --没有暴露外部端口外部不能连接docker run --name mysql -e MYSQL_ROOT_PASSWORDroot -p 3306:3306 -d mysql:tag --没有暴露外部端口# 3.进入mysql容器docker exec -it 容器名称|容器id bash# 4.外部查看mysql日志docker logs 容器名称|容器id# 5.使用自定义配置参数docker run --name mysql -v /root/mysql/conf.d:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORDroot -d mysql:tag# 6.将容器数据位置与宿主机位置挂载保证数据安全docker run --name mysql -v /root/mysql/data:/var/lib/mysql -v /root/mysql/conf.d:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORDroot -p 3306:3306 -d mysql:tag# 7.通过其他客户端访问 如在window系统|macos系统使用客户端工具访问# 8.将mysql数据库备份为sql文件docker exec mysql|容器id sh -c exec mysqldump --all-databases -uroot -p$MYSQL_ROOT_PASSWORD /root/all-databases.sql --导出全部数据docker exec mysql sh -c exec mysqldump --databases 库表 -uroot -p$MYSQL_ROOT_PASSWORD /root/all-databases.sql --导出指定库数据docker exec mysql sh -c exec mysqldump --no-data --databases 库表 -uroot -p$MYSQL_ROOT_PASSWORD /root/all-databases.sql --导出指定库数据不要数据# 9.执行sql文件到mysql中docker exec -i mysql sh -c exec mysql -uroot -p$MYSQL_ROOT_PASSWORD /root/xxx.sql8.2 安装Redis服务 # 1.在docker hub搜索redis镜像docker search redis# 2.拉取redis镜像到本地docker pull redis# 3.启动redis服务运行容器docker run --name redis -d redis:tag (没有暴露外部端口)docker run --name redis -p 6379:6379 -d redis:tag (暴露外部宿主机端口为6379进行连接) # 4.查看启动日志docker logs -t -f 容器id|容器名称# 5.进入容器内部查看docker exec -it 容器id|名称 bash # 6.加载外部自定义配置启动redis容器默认情况下redis官方镜像中没有redis.conf配置文件 需要去官网下载指定版本的配置文件1. wget http://download.redis.io/releases/redis-5.0.8.tar.gz 下载官方安装包2. 将官方安装包中配置文件进行复制到宿主机指定目录中如 /root/redis/redis.conf文件3. 修改需要自定义的配置bind 0.0.0.0 开启远程权限appenonly yes 开启aof持久化4. 加载配置启动docker run --name redis -v /root/redis:/usr/local/etc/redis -p 6379:6379 -d redis redis-server /usr/local/etc/redis/redis.conf # 7.将数据目录挂在到本地保证数据安全docker run --name redis -v /root/redis/data:/data -v /root/redis/redis.conf:/usr/local/etc/redis/redis.conf -p 6379:6379 -d redis redis-server /usr/local/etc/redis/redis.conf 8.3 安装Nginx # 1.在docker hub搜索nginxdocker search nginx# 2.拉取nginx镜像到本地[rootlocalhost ~]# docker pull nginxUsing default tag: latestlatest: Pulling from library/nginxafb6ec6fdc1c: Pull complete b90c53a0b692: Pull complete 11fa52a0fdc0: Pull complete Digest: sha256:30dfa439718a17baafefadf16c5e7c9d0a1cde97b4fd84f63b69e13513be7097Status: Downloaded newer image for nginx:latestdocker.io/library/nginx:latest# 3.启动nginx容器docker run -p 80:80 --name nginx01 -d nginx# 4.进入容器docker exec -it nginx01 /bin/bash查找目录: whereis nginx配置文件: /etc/nginx/nginx.conf# 5.复制配置文件到宿主机docker cp nginx01(容器id|容器名称):/etc/nginx/nginx.conf 宿主机名录# 6.挂在nginx配置以及html到宿主机外部docker run --name nginx02 -v /root/nginx/nginx.conf:/etc/nginx/nginx.conf -v /root/nginx/html:/usr/share/nginx/html -p 80:80 -d nginx 8.4 安装Tomcat # 1.在docker hub搜索tomcatdocker search tomcat# 2.下载tomcat镜像docker pull tomcat# 3.运行tomcat镜像docker run -p 8080:8080 -d --name mytomcat tomcat# 4.进入tomcat容器docker exec -it mytomcat /bin/bash# 5.将webapps目录挂载在外部docker run -p 8080:8080 -v /root/webapps:/usr/local/tomcat/webapps -d --name mytomcat tomcat 8.5 安装MongoDB数据库 # 1.运行mongDBdocker run -d -p 27017:27017 --name mymongo mongo ---无须权限docker logs -f mymongo --查看mongo运行日志# 2.进入mongodb容器docker exec -it mymongo /bin/bash直接执行mongo命令进行操作# 3.常见具有权限的容器docker run --name mymongo -p 27017:27017 -d mongo --auth# 4.进入容器配置用户名密码mongouse admin 选择admin库db.createUser({user:root,pwd:root,roles:[{role:root,db:admin}]}) //创建用户,此用户创建成功,则后续操作都需要用户认证exit# 5.将mongoDB中数据目录映射到宿主机中docker run -d -p 27017:27017 -v /root/mongo/data:/data/db --name mymongo mongo 8.6 安装ElasticSearch 注意:调高JVM线程数限制数量 查看是否安装过Es ps aux|grep elastic0.拉取镜像运行elasticsearch # 1.dockerhub 拉取镜像docker pull elasticsearch:6.4.2 # 2.查看docker镜像docker images # 3.运行docker镜像docker run -p 9200:9200 -p 9300:9300 elasticsearch:6.4.2docker run -d -p 9200:9200 -p 9300:9300 -e discovery.typesingle-node docker.elastic.co/elasticsearch/elasticsearch:7.15.1启动出现如下错误 1. 预先配置 # 1.在centos虚拟机中修改配置sysctl.confvim /etc/sysctl.conf # 2.加入如下配置vm.max_map_count262144 # 3.启用配置sysctl -p注这一步是为了防止启动容器时报出如下错误bootstrap checks failed max virtual memory areas vm.max_map_count [65530] likely too low, increase to at least [262144] 2.启动EleasticSearch容器 # 0.复制容器中data目录到宿主机中docker cp 容器id:/usr/share/share/elasticsearch/data /root/es # 1.运行ES容器 指定jvm内存大小并指定ik分词器位置docker run -d --name es -p 9200:9200 -p 9300:9300 -e ES_JAVA_OPTS-Xms128m -Xmx128m -v /root/es/plugins:/usr/share/elasticsearch/plugins -v /root/es/data:/usr/share/elasticsearch/data elasticsearch:6.4.23.安装IK分词器 # 1.下载对应版本的IK分词器wget https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v6.4.2/elasticsearch-analysis-ik-6.4.2.zip# 2.解压到plugins文件夹中yum install -y unzipunzip -d ik elasticsearch-analysis-ik-6.4.2.zip# 3.添加自定义扩展词和停用词cd plugins/elasticsearch/configvim IKAnalyzer.cfg.xmlpropertiescommentIK Analyzer 扩展配置/comment!--用户可以在这里配置自己的扩展字典 --entry keyext_dictext_dict.dic/entry!--用户可以在这里配置自己的扩展停止词字典--entry keyext_stopwordsext_stopwords.dic/entry/properties# 4.在ik分词器目录下config目录中创建ext_dict.dic文件 编码一定要为UTF-8才能生效vim ext_dict.dic 加入扩展词即可 # 5. 在ik分词器目录下config目录中创建ext_stopword.dic文件 vim ext_stopwords.dic 加入停用词即可# 6.重启容器生效docker restart 容器id # 7.将此容器提交成为一个新的镜像docker commit -axiaochen -mes with IKAnalyzer 容器id xiaochen/elasticsearch:6.4.24. 安装Kibana # 1.下载kibana镜像到本地docker pull kibana:6.4.2# 2.启动kibana容器docker run -d --name kibana -e ELASTICSEARCH_URLhttp://10.15.0.3:9200 -p 5601:5601 kibana:6.4.210.Docker中出现如下错误解决方案 [rootlocalhost ~]# docker search mysql 或者 docker pull 这些命令无法使用 Error response from daemon: Get https://index.docker.io/v1/search?qmysqln25: x509: certificate has expired or is not yet valid注意:这个错误的原因在于是系统的时间和docker hub时间不一致,需要做系统时间与网络时间同步 # 1.安装时间同步sudo yum -y install ntp ntpdate # 2.同步时间sudo ntpdate cn.pool.ntp.org # 3.查看本机时间date # 4.从新测试9.Dockerfile 9.1 什么是Dockerfile Dockerfile可以认为是Docker镜像的描述文件是由一系列命令和参数构成的脚本。主要作用是用来构建docker镜像的构建文件。 通过架构图可以看出通过DockerFile可以直接构建镜像 9.2 Dockerfile解析过程 9.3 Dockerfile的保留命令 官方说明:https://docs.docker.com/engine/reference/builder/ 保留字作用FROM当前镜像是基于哪个镜像的 第一个指令必须是FROMMAINTAINER镜像维护者的姓名和邮箱地址RUN构建镜像时需要运行的指令EXPOSE当前容器对外暴露出的端口号WORKDIR指定在创建容器后终端默认登录进来的工作目录一个落脚点ENV用来在构建镜像过程中设置环境变量ADD将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar包COPY类似于ADD拷贝文件和目录到镜像中将从构建上下文目录中原路径的文件/目录复制到新的一层的镜像内的目标路径位置VOLUME容器数据卷用于数据保存和持久化工作CMD指定一个容器启动时要运行的命令Dockerfile中可以有多个CMD指令但只有最后一个生效CMD会被docker run之后的参数替换ENTRYPOINT指定一个容器启动时要运行的命令ENTRYPOINT的目的和CMD一样都是在指定容器启动程序及其参数 9.3.1 FROM 命令 基于那个镜像进行构建新的镜像,在构建时会自动从docker hub拉取base镜像 必须作为Dockerfile的第一个指令出现 语法: FROM image FROM image[:tag] 使用版本不写为latest FROM image[digest] 使用摘要9.3.2 MAINTAINER 命令 镜像维护者的姓名和邮箱地址[废弃] 语法: MAINTAINER name9.3.3 RUN 命令 RUN指令将在当前映像之上的新层中执行任何命令并提交结果。生成的提交映像将用于Dockerfile中的下一步 语法: RUN command (shell form, the command is run in a shell, which by default is /bin/sh -c on Linux or cmd /S /C on Windows) RUN echo helloRUN [executable, param1, param2] (exec form) RUN [/bin/bash, -c, echo hello]9.3.4 EXPOSE 命令 用来指定构建的镜像在运行为容器时对外暴露的端口 语法: EXPOSE 80/tcp 如果没有显示指定则默认暴露都是tcp EXPOSE 80/udp9.3.5 CMD 命令 用来为启动的容器指定执行的命令,在Dockerfile中只能有一条CMD指令。如果列出多个命令则只有最后一个命令才会生效。 注意: Dockerfile中只能有一条CMD指令。如果列出多个命令则只有最后一个命令才会生效。 语法: CMD [executable,param1,param2] (exec form, this is the preferred form) CMD [param1,param2] (as default parameters to ENTRYPOINT) CMD command param1 param2 (shell form)9.3.6 WORKDIR 命令 用来为Dockerfile中的任何RUN、CMD、ENTRYPOINT、COPY和ADD指令设置工作目录。如果WORKDIR不存在即使它没有在任何后续Dockerfile指令中使用它也将被创建。 语法: WORKDIR /path/to/workdirWORKDIR /a WORKDIR b WORKDIR c 注意:WORKDIR指令可以在Dockerfile中多次使用。如果提供了相对路径则该路径将与先前WORKDIR指令的路径相对9.3.7 ENV 命令 用来为构建镜像设置环境变量。这个值将出现在构建阶段中所有后续指令的环境中。 语法 ENV key value ENV keyvalue ...9.3.8 ADD 命令 用来从context上下文复制新文件、目录或远程文件url并将它们添加到位于指定路径的映像文件系统中。 语法: ADD hom* /mydir/ 通配符添加多个文件 ADD hom?.txt /mydir/ 通配符添加 ADD test.txt relativeDir/ 可以指定相对路径 ADD test.txt /absoluteDir/ 也可以指定绝对路径 ADD url 9.3.9 COPY 命令 用来将context目录中指定文件复制到镜像的指定目录中 语法: COPY src dest COPY [src,... dest]9.3.10 VOLUME 命令 用来定义容器运行时可以挂在到宿主机的目录 语法: VOLUME [/data]9.3.11 ENTRYPOINT命令 用来指定容器启动时执行命令和CMD类似 语法: ENTRYPOINT [executable, param1, param2] ENTRYPOINT command param1 param2ENTRYPOINT指令往往用于设置容器启动后的第一个命令这对一个容器来说往往是固定的。 CMD指令往往用于设置容器启动的第一个命令的默认参数这对一个容器来说可以是变化的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/85172.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

新郑网站优化网站子目录绑定二级域名

在Java开发开源框架中,首屈一指的应该若依,在行业里,不管小公司中公司还是大公司,都能够看到若依项目的身影。足以见得 若依框架的受众之大。 RuoYi-Cloud RuoYi-Cloud 是一个 Java EE 分布式微服务架构平台,基于经典…

深圳自适应网站公司平面设计要素

本实战教程主要介绍了如何使用Java配置方式来使用Spring MVC框架。相较于XML配置方式,Java配置方式提供了一种更为简洁和灵活的配置方法。 项目创建与配置 创建一个Jakarta EE项目,并设置项目名称和位置。选择Jakarta EE 10版本,不添加依赖&a…

杭州网站关键词开通微信公众号

1 对关系模型叙述错误的是()。选择一项:用二维表表示关系模型是其一大特点建立在严格的数学理论,集合论和谓词演算公式的基础之上微机 DBMS 绝大部分采取关系数据模型不具有连接操作的 DBMS 也可以是关系数据库系统正确答案是:建立在严格的数…

h5企业网站模板app网站开发学习

cryptjs是一个第三方密码加密库,是对原有bcrypt的优化,优点是不需要安装任何依赖 安装 引入bcryptjs库var bcrypt require(bcryptjs); 异步用法(Async) //生成hash密码 var bcrypt require(bcryptjs); bcrypt.genSalt(10, function(err, salt) {bcry…

建设网站过程视频山西网络网站建设销售公司

项目场景: 项目首页使用RadioGroupRadioButtonFragment实现页面切换,出现了一个问题fragment会出现重叠问题,就是一个fragment显示了两层, 并不是必现问题。 经过排查发现是项目主页面Activity被销毁重建了,但是之前…

电商网站模板引擎关键词优化计划

1.打开后台账号设置 2.找到左下角的Developer settings 3.找到Personal access tokens 的 Tokens(classic) 4.选择创建新证书 5.填写证书信息 6.点击生成证书,复制证书并且保存起来(血泪教训,证书只会在创建时显示一次,以后就再也…

台州百度搜索优化企业排名优化公司

2019独角兽企业重金招聘Python工程师标准>>> Max Points on a Line Given n points on a 2D plane, find the maximum number of points that lie on the same straight line. 题目是:在2D平面内给N个点,求最多多少个点在一个直线上. 以下是AC的解决方式: /*** Defi…

建设银行短信开通网站网站建设可行性方案模板

<canvas>标签定义图形&#xff0c;比如图表和其他图像&#xff0c;你必须用脚本来绘制图形。 在画布上&#xff08; Canvas &#xff09;画一个共红色矩形&#xff0c;渐变矩形&#xff0c;彩色矩形&#xff0c;和一些彩色文字。 什么是 Canvas&#xff1f; HTML5<c…

宁波网站免费建设服务平台深圳美容网站建

1.联想笔记本电脑WiFi图标不见了,怎么回事吧,试了很多方法一、无线网卡开关未打开&#xff1b;1、查看周边有没有手动百机械开关&#xff0c;一般在前面板&#xff0c;上面标有无线符号。2、按一下Fn无线信号键(度F几中的一个)找打无线WIFI3、打开控制机板&#xff0c;右上角查…

国外推广网站有哪些音乐影视网站建设方案

1、演示 前言&#xff1a;目前Vue有两种仓库&#xff0c;一种是Vuex&#xff0c;一种是Pinia&#xff0c;懂得都懂&#xff0c;这里就不详细介绍这两者的区别了 2、什么是持久化 仓库里面的数据是需要跨越页面周期的&#xff0c;当页面刷新之后数据还在&#xff0c;在默认情况下…

米拓建站怎么样hr系统管理软件排名

1.Html网页前端添加作者开发信息 2. Html网页添加版权信息 3. Css添加作者开发信息 4. JavaScript添加作者开发信息 5. C井后端代码添加作者开发信息 6. Dll内裤添加作者开发信息 7.应用程序添加开发作者信息&#xff0c;著作权&#xff0c;应用版权信息 下载地址&#…

响应式学校网站怎么做视频的网站

先说一下自己的情况&#xff0c;本科生&#xff0c;2019年我通过校招踏入了成都一家软件公司&#xff0c;开始了我的职业生涯。那时的我&#xff0c;满怀热血和憧憬&#xff0c;期待着在这个行业中闯出一片天地。然而&#xff0c;随着时间的推移&#xff0c;我发现自己逐渐陷入…

网站页面设计费用58企业网站怎么做

一、Redis持久化的两种方法&#xff1a; RDB&#xff08;Redis DataBase Backup file&#xff09;Redis数据备份文件 与AOF&#xff08;Append Only File&#xff09;追加文件 二、RDB 1、介绍 RDB 简单来说就是将物理内存中的数据快照写入磁盘中,当Redis实例宕机时&…

建设厅网站关于建筑资质合并做外贸需要英文网站

总体&#xff1a; 提前进去&#xff0c;原本预计30min的面试&#xff0c;面了快60分钟&#xff0c;面的真的巨细节&#xff0c;对基本的八股没有问的很深入&#xff0c;但是&#xff0c;有关测试&#xff0c;实习&#xff0c;项目还是挺多的&#xff0c;基本把所有计算机相关的…

外贸网站优化服务自己做的网站怎么发布win7

标题索引事务作用事务流程隔离级别实例验证事务作用事务是确保数据库系统数据的完整性的功能&#xff0c;如现在互联网行业支付业务&#xff0c;不管服务器出于什么原因异常中断&#xff0c;客户要么支付成功要么支付不成功&#xff0c;支付成功数据库金额即会发生变化&#xf…

中小企业网站建设价格制作动画片的软件

8086/8088 存储器分段概念 这一节主要讲述8086/8088 存储器分段的概念。 目的 从8086 CPU开始采用了分段的方法管理存储器&#xff0c;只有充分理解存储器分段的概念和存储器逻辑地址和物理地址的关系&#xff0c;才能有助于我们掌握8086/8088汇编语言。 存储器分段的原因 在此…

网站备案好处温州做网站费用

目录 1.过滤敏感词 1.1 定义前缀树 1.2 根据敏感词,初始化前缀树 1.3 编写过滤敏感词方法

免费申请的网站wordpress下载站会员系统

目录 一、性能模式 步骤1. 启用性能模式 步骤2. 查询性能数据 步骤3. 分析性能数据 步骤4. 优化与调整 注意事项 二、慢查询日志 步骤1. 启用慢查询日志

怎么样关闭网站上海网站建设集中

微软总裁兼首席执行官萨提亚纳德拉欢迎 Mustafa Suleyman 和 Karn Simonyan 加入微软公司&#xff0c;领导一个新成立的部门 —— Microsoft AI&#xff0c;旨在开发 Copilot 和其他的面向消费者的 AI 产品和研究。 Mustafa Suleyman 将担任 Microsoft AI 执行副总裁&#xf…

网站 建设理由辽宁地矿建设集团有限公司网站

济南“樊然”主题餐厅设计莘县澄里甜品店设计聊城凤凰台星际电影公馆设计临沂市爱萌宠物医院设计定陶区云想衣服装店设计任城区曜龙休闲会所设计莘县衍界咖啡馆设计金乡啡尝嘢休闲吧设计聊城市皮肤病医院门诊设计禹城蜗牛书吧设计万达广场小乌托早教中心设计古城区栖居民宿设计…