博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
nodejs服务器部署教程一
阅读量:5158 次
发布时间:2019-06-13

本文共 2801 字,大约阅读时间需要 9 分钟。

第一篇教程紧紧让你输出一个

环境介绍

服务器环境:ubuntu(16.04)64位

本地环境:windows10 64位
连接工具:

ubuntu安装和基本配置

我的ecs是在阿里云买的,购买的时候镜像选择ubuntu16.04,现在在搞活动比较便宜,我买的香港地区的不用备案,购买后本地打开mobaxterm,点击session,输入ip确定,输入root,然后输入密码,会看到下面的界面:

1027889-20170707215834456-1771172036.png

连接远程服务器,接下来我参考了阮一峰老师的

addgroup wmui添加用户组
useradd -d /home/wmui -s /bin/bash -m wmui创建wmui用户
passwd wmui设置密码,如果忘记密码,也可用此命令重置密码
usermod -a -G wmui wmui 添加用户到组
visudo设置sudo权限
然后会跳转到下面页面1027889-20170707220004206-1635082678.png

root ALL=(ALL:ALL) ALL下面添加wmui ALL=(ALL) NOPASSWD: ALL

ctrl+x保存退出
接下来打开一个新的窗口,测试是否登陆成功1027889-20170707222307409-377738348.png

ssh无密码登陆配置

首先你需要在本地安装git并生成id_rsa.pub,打开命令行

在本地生成公钥和私钥:
ssh-keygen -t rsa -b 4096 -C "1719442545@qq.com"
在服务器生成公钥和私钥:
ssh-keygen -t rsa -b 4096 -C "1719442545@qq.com"
在服务器窗口输入:
echo "[your public key]" > ~/.ssh/authorized_keys将本机的公钥拷贝到服务器的authorized_keys文件
1027889-20170707223312800-648370006.png
完成以上操作,测试是否生效,重启服务:sudo service ssh restart新打开一个窗口,输入用户名回车,登陆成功

安全项配置:

我在搭建时候没有设置这一项,所以没有测试这项

编辑SSH配置文件/etc/ssh/sshd_config:修改port为1025到65536之间的任意一个整数
在末尾添加: AllowUsers [username]
此时登陆时需要端口号: -p [25000] [username]
fail2ban系统监控软件安装:
sudo apt-get update
sudo apt-get upgrade
sudo apt-get install fail2ban
sudo service fail2ban status 查看fail2ban运行状态
sudo service fail2ban stop 关闭fail2ban
sudo service fail2ban start 开启fail2ban

nodejs环境搭建

安装常用软件

sudo apt-get install vim openssl build-essential libssl-dev wget curl git
nvm安装
wget -qO- https://raw.githubusercontent.com/creationix/nvm/v0.33.2/install.sh | bash
打开新的窗口
nvm install node v8.1.3
nvm use node v8.1.3
nvm alias default v8.1.3 默认版本
安装常用node包
npm i pm2 webpack vue-cli -g

nginx服务器代理设置

sudo apt-get install nginx 通过nginx -v查看版本号

打开/etc/nginx/conf.d/文件夹,创建配置文件test-8081.conf,内容如下:

upstream hello {    server 127.0.0.1:8081;}server {    listen 80;    server_name hello.86886.wang;    location / {        proxy_set_header Host  $http_host;        proxy_set_header X-Real-IP  $remote_addr;          proxy_set_header X-Forwarded-For  $proxy_add_x_forwarded_for;        proxy_set_header X-Nginx-proxy true;        proxy_pass http://hello;        proxy_redirect off;    }}

解析你的域名到你的服务器ip,例如解析hello.86886.wang

sudo nginx -t 查看是否配置成功
1027889-20170707224919706-1672492606.png

sudo nginx -s reload 重启服务器

注意:我在第一次配置的时候遇到了黄色警告,但是不影响使用,如果你也遇到了,向下面一样解决
打来etc/hosts,在127.0.0.1 localhost下面添加127.0.1.1 iZj6cas9txr6crspqecn4zZ其中 iZj6cas9txr6crspqecn4zZ是你的ecs实例名称
1027889-20170707225552737-1768181819.png
ok完成以上操作,接下来开始写hello world

创建和部署hello world

以root用户身份在根目录下创建www目录,www目录下创建hello文件夹,里面就一个文件,hello.js,内容如下:

const http = require('http')http.createServer(function(req,res) {res.writeHead(200,{'Content-Type':'text/plain'})res.end('hello world')}).listen(8081)console.log('server test')

进入到www下hello文件夹下

hello world测试:
pm2 start hello.js
pm2 list 查看启动的应用
pm2 show hello 查看详细信息
pm2 logs 查看当前信息
pm2 stop hello 停止hello
pm2 delete hello 删除hello
1027889-20170707230538847-44284946.png
如图所示表示启动成功,输入hello.86886.wang就可以看到hello world了
接下来计划:
nodejs服务器部署教程二:
nodejs服务器部署教程三:部署基于nodejs+vue+mongodb的项目
nodejs服务器部署教程四:实现https

转载于:https://www.cnblogs.com/yesyes/p/7119644.html

你可能感兴趣的文章
hadoop2.2.0+hive-0.10.0完全分布式安装方法
查看>>
django知识点总结
查看>>
C++ STL stack、queue和vector的使用
查看>>
使用Reporting Services时遇到的小问题
查看>>
约瑟夫问题
查看>>
Arduino 报错总结
查看>>
树莓派Android Things物联网开发:树莓派GPIO引脚图
查看>>
矩阵快速幂---BestCoder Round#8 1002
查看>>
js兼容公用方法
查看>>
如何将应用完美迁移至Android P版本
查看>>
【转】清空mysql一个库中的所有表的数据
查看>>
基于wxPython的python代码统计工具
查看>>
淘宝JAVA中间件Diamond详解(一)---简介&快速使用
查看>>
Hadoop HBase概念学习系列之HBase里的宽表设计概念(表设计)(二十七)
查看>>
Kettle学习系列之Kettle能做什么?(三)
查看>>
Day03:Selenium,BeautifulSoup4
查看>>
awk变量
查看>>
mysql_对于DQL 的简单举例
查看>>
35. Search Insert Position(C++)
查看>>
[毕业生的商业软件开发之路]C#异常处理
查看>>