本文基于工作需要,做的读书笔记
因为公司用阿里云、亚马逊云,然后自己有一个腾讯云,所以身为一个小前端,服务器的知识还是要一点点。因为项目需要,最近连着在不同的服务器上玩了一阵,那叫一个学习啊,总算把各种安装搞会了。让我们一起来看看吧。
前提条件:
你已经了解基本的Linux知识。
编码环境:
系统:OS X EI Capitan
版本:10.11.6
ubuntu的环境安装
服务器环境:
系统:ubuntu
版本:14.04 (腾讯云)
在腾讯云服务器的控制台页面,拿到它的外网IP和生成下载SSH密钥。比如:
外网IP为:119.29.152.34
SSH密钥下载到本地文件路径:/MRain/Tencent/Season (文件名为Season)
我们使用SSH方式登录到服务器:(密码登录方式我没有仔细看,没找到)
$ sudo ssh -i /MRain/Tencent/Season ubuntu@119.29.152.34
Password: 输入你的本机密码
登录成功!将会看到类似这样的画面:
ubuntu@VM-138-153-ubuntu:~$
接下来开始安装环境。
1、安装node
参考网站:nodeJs官网。安装命令如下:
$ curl -sL https://deb.nodesource.com/setup_6.x | sudo -E bash -
$ sudo apt-get install -y nodejs
$ sudo apt-get install -y build-essential
注:apt-get是Ubuntu比较常用的获取或安装方式。
2、安装nginx
(其实,如果你是跑一个nodejs,不装nginx也是可以的,不是必须的。)
参考网站:ubuntu的Nginx的安装参考。
如果要运行一个nodejs的服务,那最好的选择应该是nginx,而不是apache。使用apache貌似需要设置反向代理,这里因为我不是很清楚,所以跳过。等到我真正需要apache的时候,我再去认真了解一下。
安装命令如下:
$ sudo apt-get update //先更新服务器系统(建议)
$ sudo apt-get install nginx
$ sudo /etc/init.d/nginx start //测试启动
安装好了nginx后,需要知道如何配置启动。
一般来说,安装后的nginx的配置文件的路径为/etc/nginx/sites-available/default,那直接用sudo权限去编辑它。命令如下:
$ sudo vi /etc/nginx/sites-available/default
打开这个文件,你大概可以看到如下代码:
server {
listen 80;
server_name example.com;
location / {
proxy_pass http://APP_PRIVATE_IP_ADDRESS:8080;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}
那现在来改一下,记着根据你的实际端口应用,举一反三,不要照抄照搬。
编辑的时候,需要切换为英文输入,单击i转变为插入字符,编辑结束后使用:wq保存。
如果不熟悉Linux命令,可以谷歌一下。
server {
listen 80;
server_name 你的域名;
location / {
proxy_pass 127.0.0.1:你的端口;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}
配置好后,需要重启nginx服务,使用命令:
$ sudo service nginx restart
实际上这里的工作就是映射,80端口指向了你的nodejs服务端口。如果你的域名已经设置好了,并指向此服务器,那么通过域名可以直接访问你跑起来的nodejs服务了。两种访问方式都可以:
- 域名方式访问
- 服务器公网IP:nodejs服务端口,比如说119.29.152.34:3000
不管你是否需不需要mysql、mongodb数据库,下面扩展就来看看。
3、安装mongodb
参考网站:
Install MongoDB Community Edition on Ubuntu
在Ubuntu 14.04 64bit上安装MongoDB并测试
参照下面的命令,依次执行:
$ sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv EA312927
$ echo "deb http://repo.mongodb.org/apt/ubuntu trusty/mongodb-org/3.2 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.2.list
$ sudo apt-get update
$ sudo apt-get install -y mongodb-org //不指定
$ sudo apt-get install -y mongodb-org=3.2.10 mongodb-org-server=3.2.10 mongodb-org-shell=3.2.10 mongodb-org-mongos=3.2.10 mongodb-org-tools=3.2.10
确认当前安装的MongoDB版本 要执行一遍
$ echo "mongodb-org hold" | sudo dpkg --set-selections
$ echo "mongodb-org-server hold" | sudo dpkg --set-selections
$ echo "mongodb-org-shell hold" | sudo dpkg --set-selections
$ echo "mongodb-org-mongos hold" | sudo dpkg --set-selections
$ echo "mongodb-org-tools hold" | sudo dpkg --set-selections
那么,如果没有遇到错误的话,应该是正常成功安装了。
了解一下mongodb的使用吧。
$ sudo service mongod start // 启动
Verify that MongoDB has started successfully
Verify that the mongod process has started successfully by checking the contents of the log file at/var/log/mongodb/mongod.log for a line reading
[initandlisten] waiting for connections on port <port>
where <port> is the port configured in /etc/mongod.conf, 27017 by default.
$ sudo service mongod stop // 停止
$ sudo service mongod restart // 重新启动
$ sudo service mongod status // 查看当前数据库状态
$ mongo // 建立一个客户端
// 以下几个mongo操作命令,可能会告诉你一些mongodb的简单操作。
> help 显示帮助信息
> db 查看当前连接的数据库
> show dbs 显示所有数据库列表
> use mydb 切换到mydb数据库
> db 查看当前存在的数据库,
> use mydb 要创建一个新的数据库,使用下面的命令:
>
> exit
> 或者直接按Ctrl+C中断退出
4、安装pm2
如果真的要在生产环境运行nodeJS,那就需要一个管理工具,比如forever,pm2。其中,pm2的安装方法如下:
$ sudo npm install pm2 -g // 注意:一定是在全局环境下安装
看一下它的相关命令吧:
$ pm2 start hello.js // 启动
$ pm2 startup ubuntu // 自启动
// 执行后,他会返回几句命令,注意执行最后那一行sudo那句
[PM2] You have to run this command as root
[PM2] Execute the following command :
[PM2] sudo su -c "env PATH=$PATH:/opt/node/bin pm2 startup ubuntu -u sammy --hp /home/sammy" // 跑一下这句(每个系统可能不一样,注意)
$ sudo su -c "env PATH=$PATH:/opt/node/bin pm2 startup ubuntu -u sammy --hp /home/sammy"
$ pm2 list // 查看跑了哪些服务
$ pm2 stop example // 关掉服务,这里的example可以是name,也可以是id
$ pm2 restart example // 重启服务
$ pm2 info example // 查看信息
$ pm2 monit // 监视服务运行日志
最后一点,也是我们需要的知道的。
常常使用pm2运行生产环境的node服务,更多的时候是写了一个配置文件,比如命名为process.json,并指定运行环境为production。然后我们只要跑起这个文件就可以了,配置都写在里面。
$ pm2 start process.json --env production
来看看如何配置最简单的process.json,代码如下:
{
"apps" : [{
"name" : "AppName", //你的APP的名称
"script" : "./bin/www", //跑起node服务的命令
"watch" : true, //监视
"env": {
"NODE_ENV": "development",
},
"env_production" : {
"NODE_ENV": "production"
},
"instances" : 4, //生产环境的实例,是4个,或8个,或100个
"exec_mode" : "cluster" //集群模式
}]
}
如果需要了解pm2配置文件的更多信息,请自行谷歌。
5、安装git
只要跑一下命令:
$ sudo npm install git -g // 注意在全局环境下
好了,每次要部署代码,每次上传服务器使用scp命令么?好慢的吧。那么,我们使用git吧,我们的代码可以托管在github或者bitbucket,它们都是代码托管服务商。
比如使用github,我们先把本地电脑上的项目代码提交到github上,然后跑到服务器上,通过命令:
git clone https://github.com/YourGithubName/RepositoryName.git
// 需要输入密码github账号密码。
如此一来,轻松将代码放到服务器上。每次如果更新代码,只需要本地电脑使用git push,提交到github。再到服务器上,使用git pull下拉获取最新就可以啦。更新代码后,继续重启node服务喔。重启命令前面说了。
好了,想要去试试么?部署一个自己的小站点、服务接口什么,玩玩看。
centOS的环境安装
服务器环境:
系统:centOS
版本:7 (亚马逊云)
既然说的是亚马逊云服务器,那么总需要先有个账号吧,那先登录到亚马逊中国服务器。
登录网址:https://www.amazonaws.cn/
注册并登陆成功,将看到如下画面。
如何使用亚马逊云呢?
先去EC2里面搭建一台服务器,服务器的系统,这里选CentOS,我们现在要研究这个。
进入EC2的控制面板,在默认页面,可以看到当前创建的所有服务器实例。单击某一个已创建的服务器实例,可以看到此服务器的一般信息,这里可以查看到外网IP。然后左侧的菜单,往下看,有一项是“密钥对”,那么单击它进去,创建一个SSH密钥,并下载到本地。
ps:这里就不截图了,信息保密。比如:
外网IP为:54.223.74.164
SSH密钥下载到本地文件路径:/Mine/Project/mine.pem (ssh密钥文件名为mine.pem)
我们使用SSH方式登录到服务器:
$ sudo ssh -i ssh文件路径 服务器名称@服务器IP
// 方式一:服务器名称全称
$ sudo ssh -i /MRain/Project/fusion/fusiond.pem ec2-user@ec2-54-223-94-164.cn-north-1.compute.amazonaws.com.cn
// 方式二:服务器名称+IP
$ sudo ssh -i /MRain/Project/fusion/fusiond.pem ec2-user@54.223.94.164
Password: 输入你的本机密码
// 远程登录成功!将会看到类似这样的:
[ec2-user@ip-172-31-19-101 ~]$
正常来说,接下来就要安装环境。但是,你可以试试安装,如果说没有权限,就可能需要使用root权限安装。这应该是最麻烦的地方,我在这里搞了很久,不使用root权限安装环境,基本上每个都没有装成功。好一段时间不知道怎么解决。你可以试试是不是也有这个问题,还是只会在亚马逊云服务器的centOS上才会遇到。
1、如何获取root账号
1)仍然需要用前面的登录方法,远程连接到EC2服务器。
2)创建root密码,输入如下命令
$ sudo passwd root
3)然后会提示你输入new password。那么你就设置一下密码。这里需要输入2次,后面那次是验证是否一致。那这样,密码建立好了。
4)切换到root,输入如下命令
$ su root
注意:如果你不需要使用root直接登陆服务器,那么你不需要执行后面的这几步。
你只需要普通SSH登录后,需要安装的话,使用su root切换过去。不安装再切换回来,就可以了。
我是这样的,没有去设置使用root直接登陆。
如真需设置,你可以参考下面这几步。
5)那学会了切换,如何使用root直接登陆服务器呢。去修改PasswordAuthentication字段,默认为no,把no改成yes。修改配置文件,输入如下命令:
$ vim /etc/ssh/sshd_config
6)修改保存后,需要重新启动下sshd。输入如下命令
$ su ec2-user //先切换回去
$ sudo /sbin/service sshd restart
7)然后再切换到root身份
$ su root
8)再为原来的”ec2-user”添加登录密码。输入如下命令:
$ passwd ec2-user
9)同样输入两次密码。之后你可以通过root登录服务啦。
好了好了。现在可以真正开始安装环境了。
不用root权限安装,掉坑里,走很多弯路的。
警告:以下安装均需要切换到root权限下安装!!!!
2、安装node[root权限下]
参考网站:Installing Node.js via package manager
安装命令如下:
$ curl --silent --location https://rpm.nodesource.com/setup_6.x | bash -
$ yum -y install nodejs
注:yum是centOS比较常用的安装方式
3、安装nginx[root权限下]
参考网站:
How To Set Up nginx Virtual Hosts (Server Blocks) on CentOS 6
How To Install Nginx on CentOS 7
安装命令如下:
$ sudo yum install epel-release
$ sudo yum install nginx
// 安装后测试启动
$ sudo /etc/init.d/nginx start
安装好了nginx后,我们需要知道如何配置启动。
一般来说,安装后的nginx的配置文件的路径为/etc/nginx/...
这一块的配置,和前面ubuntu的安装配置,是不一样的。
因为在centOS系统里,安装后的nginx,是缺少2个文件夹的。
他们是sites-available和sites-enabled,你需要自己创建他们。
使用如下命令:
$ su root //这一步你应该在安装前已经切换,这里提示你一下,不需要执行的
$ cd /etc/nginx
$ mkdir sites-available
$ mkdir sites-enabled
接着,我们需要复制文件夹conf.d的默认配置文件,到新建的2个文件夹。命令如下:
$ cp ./conf.d/virtual.conf ./sites-available/default.conf
$ cp ./conf.d/virtual.conf ./sites-enabled/default.conf
紧接着,我们要去修改一下配置文件,命令如下:
$ sudo vi /etc/nginx/nginx.conf
// 在显示的文件内容中,找到下面这句
...
include /etc/nginx/conf.d/*.conf;
...
在它的后面插入一句,目的是为了将新的配置文件引入,是它变为并保存:
...
include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
...
接着,我们需要去修改那2个文件的default.conf,接近尾声了。大概编辑成下面这个样子,具体你可能需要查阅其它文献。我也需要更深入学习nginx的配置。所以,这里如果给你挖了个坑,望见谅。我是如下这么设置的。
// 文件 /sites-available/default.conf
server {
listen 80;
server_name 54.223.74.164;
location / {
# root html;
# index index.html index.htm;
proxy_pass http://127.0.0.1:8080;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}
// 文件 /sites-enabled/default.conf
server {
listen 80;
server_name 54.223.74.164;
location / {
# root html;
# index index.html index.htm;
proxy_pass http://127.0.0.1:8080;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}
最后重启服务器,命令如下;
$ sudo /etc/init.d/nginx restart
实际上这里的工作就是映射,80端口指向了你的nodejs服务端口。如果你的域名已经设置好了,并指向此服务器,那么通过域名可以直接访问你跑起来的nodejs服务了。两种访问方式都可以:
- 域名方式访问
- 服务器公网IP:nodejs服务端口,比如说119.29.152.34:3000
不管你是否需不需要mysql、mongodb数据库,下面扩展就来看看。
4、安装mysql[root权限下]
参考网站:Install a MySQL server on CentOS
$ sudo yum install mysql-server
$ sudo /sbin/service mysqld start
$ sudo /usr/bin/mysql_secure_installation
// 一路回车enter
//To apply some reasonable security to your new MySQL server answer yes to all the prompts.
简单的mysql使用命令,可以谷歌一下。
5、安装pm2[root权限下]
安装很简单,命令如下:
$ sudo npm install pm2 -g
具体pm2的使用方法,请去阅读文章前面内容。
6、安装git[root权限下]
注意,下面这个命令是不行的,错误的,不要执行。
$ sudo npm install git -g
正确的安装方式,是下面这个命令:
$ sudo yum install git
$ git --version
具体git的使用方法,请去阅读文章前面内容。
后记
如果你不想使用pm2,想去用forever.js的话,安装和使用也很简单。
// 安装
$ sudo npm install forever -g
// 启动一个服务
$ sudo forever restart index.js
到这里,就先结束了。
学习是一条漫漫长路,每天不求一大步,进步一点点就是好的。