利用Docker部署的服务器环境已经成为目前主流。为了实现高负载、易于拓展,我们采用Nginx作为反代,Redis记录访问日志。(主机服务器环境:CentOS7.1)
创新互联建站于2013年开始,是专业互联网技术服务公司,拥有项目做网站、网站设计网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元汪清做网站,已为上家服务,为汪清各地企业和个人服务,联系电话:13518219792
yum update
yum install docker
设置开机启动:
systemctl enable docker.service
启动docker:
systemctl start docker.service
使用:
docker info
可以查看docker的信息,检查是否安装成功。
CentOS7的systemctl命令:
systemctl is-enabled servicename.service #查询服务是否开机启动
systemctl enable
.service #开机运行服务
systemctl disable .service #取消开机运行
systemctl start
.service #启动服务
systemctl stop .service #停止服务
systemctl restart
.service #重启服务
systemctl reload .service #重新加载服务配置文件
systemctl status
.service #查询服务运行状态
systemctl --failed #显示启动失败的服务与老版本对比,以httpd为例,则:
启动服务(等同于service httpd start)
systemctl start httpd.service
停止服务(等同于service httpd stop)
systemctl stop httpd.service
docker run -d -p 80:80 nginx
如果出现Warning:"Usage of loopback devices is strongly discouraged for production use."(据我所知阿里云、腾讯云及VMware中的CentOS7都会出现):
vim /etc/sysconfig/docker-storage修改里面的DOCKER_STORAGE_OPTIONS内容为:
DOCKER_STORAGE_OPTIONS="--storage-opt dm.no_warn_on_loop_devices=true"
PS:我同时在阿里云和腾讯云执行“docker run -d -p 80:80 nginx”这个命令。阿里云因为做了加速,所以很快安装完成,但腾讯云卡死。解决方法:在安全性要求不高的情况下可以使用国内镜像,否则请使用安全的网络环境和可信来源。
(注意,第二次运行这个命令的时候,请使用完整的REPOSITORY,否则部分服务器可能会有警告并自动结束docker,例如:“
docker run -p 80:80 docker.io/nginx
” )
运行
docker pull index.alauda.cn/library/nginx
docker ps
docker stop ID
其中“ID”可以用前几个字符,只要能唯一识别即可。例如上图中的容器ID,我们可以使用“1e3c3ce23d5b”,也可以使用“1e3c”来结束容器。同理,其它docker的操作也是类似的。
docker ps -l
可以查看运行过的所有docker,包括已经运行结束了的docker。
第一个命令中“docker run”后面的“-d”代表是否在后台运行,去掉这个“-d”执行“docker run -p 80:80 nginx”可以看到访问记录。使用“Ctrl+C”结束执行,则docker自动退出。因此在服务器中执行时请带上“-d”参数。
使用
docker images
可以查看安装了的所有本地镜像。
docker pull node
安装完毕后可以通过
docker run -it --rm node node --version
查看node.js版本号。
接下来上传你的源代码到服务器。例如从公司服务器克隆源代码:get clone XXX 。
确保你的源代码目录下package.json文件配置正确。
然后
docker run --rm -it -p 3000:1337 --name WebApp -v "$(pwd)":/webapp -w /webapp node npm install
或
docker run -itd -p 3000:1337 --name WebApp -v "$(pwd)":/webapp -w /webapp node npm start
安装依赖并运行程序。
-v后面的:代表分割的路径,前者表示宿主的路径(在这里也就是expressjs项目的主目录),后者表示映射到Docker容器的路径。
-w:表示将-v映射的/webapp目录设置为work directory,也就是运行node命令的目录。这个设置将覆盖Dockfiie中的设置:/Data。
其中-itd
:
--rm,运行结束后删除容器。
利用Nginx反代能够很方便的实现负载均衡。
mkdir config
在/root目录下创建一个名为config的目录用于存放Nginx的配置文件。
vim config/nginx.conf
在这个配置文件中配置反代。
server {
listen 80;
server_name 绑定的域名;
location / {
proxy_pass http://localhost:3000;
}
}
docker run -itd -p 80:80 --link WebApp:localhost -vpwd
/config/nginx.conf:/etc/nginx/conf.d/host_one.conf -vpwd
/logs:/var/log/nginx nginx
即可。访问绑定的域名,则可以访问到node.js的程序。
需要注意的是,“-v pwd
/config/nginx.conf:/etc/nginx/conf.d” 中的“pwd
/config”代表server文件的本地路径,意思是当前目录下的config文件,将会映射到docker容器的nginx配置路径。而“:”后面的路径则是服务器中的路径,默认的nginx.conf文件中包含“include /etc/nginx/conf.d/.conf;”,也就是默认载入conf.d文件夹中的.conf后缀的文件。最后执行这个命令会在当前目录下创建logs目录,存放access.log和error.log。刚开始配置的时候,最好去掉“-itd”中的“d”,运行命令查看是否存在问题。如果运行正常,先执行“docker rm $(docker ps -a -q)”清除所有已经执行过的docker,再执行带“d”的命令进入后台运行。
如果使用SSL证书,则Nginx配置文件按照证书提供商提供的设置方法设置,一般要设置443端口,则在"-p"后映射需要的端口,并且在运行nginx容器的时候设置SSL的路径:-v
采用Redis进行日志记录,方便高效。
docker run -d --name redis -p 6379:6379 redis
在启动node.js程序的时候加上“--link redis:redis”即可。其他MongoDB、MySQL之类的数据库同理。
至于需要记录什么日志,与具体的项目需求有关。一般来说我们使用Redis记录 HTTP 访问日志和应用日志。
杀死所有正在运行的容器
docker kill $(docker ps -a -q)
删除所有已经停止的容器
docker rm $(docker ps -a -q)
删除所有未打 dangling 标签的镜像
docker rmi $(docker images -q -f dangling=true)
删除所有已下载的本地镜像
docker rmi $(docker images -q)
下面关于Node.js的内容你可能也喜欢:
文章题目:基于Docker部署Node.js应用环境
网站URL:http://www.shufengxianlan.com/qtweb/news13/215263.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联