安装依赖并运行程序。
-v后面的:代表分割的路径,前者表示宿主的路径(在这里也就是expressjs项目的主目录),后者表示映射到Docker容器的路径。
-w:表示将-v映射的/webapp目录设置为work directory,也就是运行node命令的目录。这个设置将覆盖Dockfiie中的设置:/Data。
其中-itd:
i,容器的标准输入保持打开
t,Docker分配一个伪终端(pseudo-tty)并绑定到容器的标准输入
d:Docker容器跑在后台。
--rm,运行结束后删除容器。
利用Nginx反代能够很方便的实现负载均衡。
在/root目录下创建一个名为config的目录用于存放Nginx的配置文件。
在这个配置文件中配置反代。
listen 80;
server_name 绑定的域名;
location / {
proxy_pass :3000;
}
}
设置方法参考Nginx,这些我想大家都已经很熟悉了。
最后执行
即可。访问绑定的域名,则可以访问到node.js的程序。
需要注意的是,“-v <code>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 <certs-dir>:/etc/nginx/certs。
采用Redis进行日志记录,方便高效。
在启动node.js程序的时候加上“--link redis:redis”即可。其他MongoDB、MySQL之类的数据库同理。
至于需要记录什么日志,与具体的项目需求有关。一般来说我们使用Redis记录 HTTP 访问日志和应用日志。
杀死所有正在运行的容器
删除所有已经停止的容器
删除所有未打 dangling 标签的镜像
删除所有已下载的本地镜像
下面关于Node.js的内容你可能也喜欢:
在 Ubuntu 14.04/15.04 上安装配置 Node.js v4.0.0