若是你对nodejskoa2vuejs等感兴趣,请加QQ群:732189938
或者直接点击连接加入群聊【Node.js/Koa2/vuejs】:https://jq.qq.com/?_wv=1027&k...vue
全新ubuntu请先执行如下命令安装经常使用工具node
sudo apt-get install git vim wget curl openssl build-essential libssh-dev
curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash - sudo apt-get install -y nodejs
npm install pm2 -g
若是服务器已经安装了apache须要先卸载掉,由于apache占用80端口会致使nginx没法启动
依次执行如下命令python
sudo service apache2 stop update-rc.d -f apache2 remove sudo apt-get remove apache2
更新包列表nginx
sudo apt-get update
安装git
sudo apt-get install nginx
cd /etc/nginx/conf.d
建立绑定域名的虚拟机配置文件,例如:你所绑定的域名是 fuck.baidu.net 项目所在的node端口是6661github
vi fuck-baidu-net-6661.conf
将如下配置内容粘贴进去,根据实际状况自行修改web
server { listen 80; listen [::]:80; server_name baidu.com; root /var/www/baidu.com/; # logging access_log /var/log/nginx/baidu.com.access.log; error_log /var/log/nginx/baidu.com.error.log warn; # reverse proxy location / { proxy_pass http://127.0.0.1:3000; } }
重启以前,能够先检测一下配置规则mongodb
sudo nginx -t
执行上面的命令若是出现下面的提示apache
sudo: unable to resolve host XXX
则执行npm
vi /etc/hosts
修改 127.0.1.1 hostname 为 127.0.1.1 XXX
重启nginx
sudo nginx -s reload
官网安装说明 https://docs.mongodb.com/manu...
根据安装说明执行完第一步。将第二步中的安装源换成阿里云的镜像安装会比较快,以下:
echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/4.0 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.0.list
将上面的部分替换以下
echo "deb [ arch=amd64,arm64 ] https://mirrors.aliyun.com/mongodb/apt/ubuntu xenial/mongodb-org/4.0 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.0.list
更新源
sudo apt-get update
正式安装
sudo apt-get install -y mongodb-org
经常使用命令
sudo service mongod start sudo service mongod stop sudo service mongod restart
在使用SSH协议访问项目仓库以前,须要先配置好帐户/项目的SSH公钥。本地和服务器均执行
你能够按以下命令来生成 sshkey:
这一步请慎重,若是你已经生成过而且有在使用的key这一步就不要再执行了,不然会覆盖以前生成的key致使你其它须要使用这个key的没法访问
ssh-keygen -t rsa -C "xxxxx@xxxxx.com"
按照提示完成三次回车,便可生成 ssh key。经过查看 ~/.ssh/id_rsa.pub 文件内容,获取到你的 public key
cat ~/.ssh/id_rsa.pub
将ssh key复制添加到git仓库中 码云官方说明见这里 https://gitee.com/help/articl...
测试是否成功
github
ssh -T git@github.com
码云
ssh -T git@gitee.com
ssh-copy-id username@ip-address
按提示输入服务器密码,完成后会有以下提示
Number of key(s) added: 1 Now try logging into the machine, with: "ssh 'root@114.xxx.xxx.xx'" and check to make sure that only the key(s) you wanted were added.
使用以下命令测试是否能够链接服务器成功
ssh 'root@114.xxx.xxx.xx'
(好比阿里云服务器在建立实例的时候能够设置密钥对链接,阿里云会自动生成密钥文件并下载提供给你保存)
先建立ssh代理,执行以下命令
eval $(ssh-agent -s)
将阿里云下载的密钥文件添加进来,下面的密钥文件路径修改成你本身的
ssh-add ~/.ssh/aliyun-ssh-key.pem
这样就能够实现本地终端免密码登录链接服务器了
在本地终端执行下面的命令来进行第一次部署并填充远程路径
pm2 deploy production setup
每次本地git提交代码后在本地终端执行下面的名来实现自动拉取git仓库中的代码并部署
pm2 deploy production
pm2 startup pm2 save
不得不说Let's Encrypt证书作的简直太方便了,几个命令全自动搞定,无需手动作任何修改配置
依次执行下面的命令( 其它操做系统请自行在官方查看使用方法 https://certbot.eff.org/lets-... )
sudo apt-get update sudo apt-get install software-properties-common sudo add-apt-repository ppa:certbot / certbot sudo apt-get update sudo apt-get install python-certbot-nginx
安装
sudo certbot --nginx
执行上面的命令后会提示你输入你的邮箱,会检测到你nginx配置的域名,选择你要生成证书的域名序号便可;还会提示你是否在用户使用http访问的时候自动跳转到https访问,序号1是不跳转,序号2是自动跳转,建议选2
每次生成的证书有效期是90天,到期后须要从新申请,若是你想在证书到期前自动续订能够执行
sudo certbot renew --dry-run
这样certbot会在证书到期时自动帮你续订证书,这就至关于你有了永久的免费SSL证书了
$ pm2 list # 显示全部进程状态 $ pm2 monit # 监视全部进程 $ pm2 logs # 显示全部进程日志 $ pm2 stop all # 中止全部进程 $ pm2 restart all # 重启全部进程 $ pm2 reload all # 0 秒停机重载进程 (用于 NETWORKED 进程) $ pm2 stop 0 # 中止指定的进程 $ pm2 restart 0 # 重启指定的进程 $ pm2 startup # 产生 init 脚本 保持进程活着 $ pm2 web # 运行健壮的 computer API endpoint (http://localhost:9615) $ pm2 delete 0 # 杀死指定的进程 $ pm2 delete all # 杀死所有进程