操作环境
服务器:阿里云 CentOS7.3.1611
时间: 20170818
安装Git
阿里云更换了系统盘,不小心手贱,顺手更新到最新系统
# yum update
再顺手重启下
#reboot
然后再次远程登录上服务器,看下系统版本
# lsb_release -a
LSB Version: :core-4.1-amd64:core-4.1-noarch
Distributor ID: CentOS
Description: CentOS Linux release 7.3.1611 (Core)
Release: 7.3.1611
Codename: Core
默认是阿里云的yum源,懒得切换了,直接安装Git
# yum install git
······
Installed:
git.x86_64 0:1.8.3.1-6.el7_2.1
Dependency Installed:
libgnome-keyring.x86_64 0:3.8.0-3.el7 perl-Error.noarch 1:0.17020-2.el7
perl-Git.noarch 0:1.8.3.1-6.el7_2.1 perl-TermReadKey.x86_64 0:2.30-20.el7
rsync.x86_64 0:3.0.9-17.el7
Complete!
完成后顺手看下Git版本,如果顺利输出版本号,说明安装成功
# git version
git version 1.8.3.1
安装NVM并用NVM安装多版本Node.js
NVM(Node version manager)是Node.js的版本管理软件,用这货可以在Node.js各个版本间轻松切换。
首先,直接使用git将源码克隆到本地的~/.nvm目录下,并检查最新版本
# git clone https://github.com/cnpm/nvm.git ~/.nvm && cd ~/.nvm && git checkout `git describe --abbrev=0 --tags`
备份profile文件,并激活NVM
# cp /etc/profile /etc/profile.mybak
# echo ". ~/.nvm/nvm.sh" >> /etc/profile
# source /etc/profile
列出Node.js的所有版本
# nvm list-remote
由上面列出的版本列表中选择需要的Node.js版本进行安装
# nvm install v0.12.18
# nvm install v4.8.4
# nvm install v8.4.0
# nvm install v6.11.2
随便装了四个版本后,查看已安装Node.js版本,当前使用的版本为v6.11.2,貌似提示为不稳定版?
# nvm ls
v0.12.18
v4.8.4
-> v6.11.2
v8.4.0
stable -> 8.4 (-> v8.4.0) (default)
unstable -> 6.11 (-> v6.11.2) (default)
切换Node.js版本至v8.4.0
# nvm use v8.4.0
Now using node v8.4.0
卸载掉v6.11.2,再次查看当前安装版本,显示是8.4.0
# nvm uninstall v6.11.2
Uninstalled node v6.11.2
# nvm ls
v0.12.18
v4.8.4
-> v8.4.0
stable -> 8.4 (-> v8.4.0) (default)
将v8.4.0设置为默认版本,不然每次重启都需要运行 nvm use
nvm alias default stable
其他nvm命令
# nvm help
测试是否已经可用
# cd /home
#mkdir www
#vim test.js
编辑test.js文件
const http = require('http');
const server = http.createServer((req, res) => {
res.statusCode = 200;
res.setHeader('Content-Type', 'text/plain');
res.end('Hello World\n');
});
server.listen("80",'0.0.0.0' , () => {
console.log("Server running");
});
运行test.js文件
# node test.js
Server running
在浏览器打开云服务器ip,可以看到网页页面输出 Hello World
如果需要守护进程,就安装pm2
# npm install -g pm2
使用pm2守护Node.js
# pm2 start /home/www/test.js
[PM2] Starting /home/www/test.js in fork_mode (1 instance)
[PM2] Done.
┌───────┬──────┬────────┬───┬─────┬──────────┐
│ Name │ mode │ status │ ↺ │ cpu │ memory │
├───────┼──────┼────────┼───┼─────┼──────────┤
│ test │ fork │ online │ 0 │ 3% │ 7.7 MB │
└───────┴──────┴────────┴───┴─────┴──────────┘
设置每次开机都启动/home/www/test.js
# pm2 save
# pm2 startup centos
# pm2 save
安装MongoDB
从官网获得社区版下载地址,选择平台为Linux,Version 选择为 RHEL 7 Linux 64-bit x64,这里没有CentOS,所以只能选RHEL,反正也差不多。点击下方的Package Manager:Instructions for installing with yum,进入说明文档。
根据上面的官方说明,新建yum源文件
#vim /etc/yum.repos.d/mongodb-org-3.4.repo
然后填入yum源配置,保存并退出,如果想省去gpg验证,这里可以设置gpgcheck=0
[mongodb-org-3.4]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.4/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc
开始yum安装MongoDB
#yum -y install mongodb-org
漫长的等待后(吐槽下真的好慢啊,不管是yum还是wget直接装),安装完成
默认的一部分目录如下:
配置文件在:/etc/mongod.conf
数据文件在:/var/lib/mongo
日志文件在:/var/log/mongodb
编辑配置文件可以参考官方文档
启动MongoDB的服务
# systemctl start mongod.service
添加到开机启动
# systemctl enable mongod.service
# systemctl daemon-reload
启动进入MongoDB
# mongo
MongoDB shell version v3.4.7
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.4.7
Server has startup warnings:
2017-08-30T00:02:32.805+0800 I STORAGE [initandlisten]
2017-08-30T00:02:32.805+0800 I STORAGE [initandlisten] ** WARNING: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine
2017-08-30T00:02:32.805+0800 I STORAGE [initandlisten] ** See http://dochub.mongodb.org/core/prodnotes-filesystem
2017-08-30T00:02:33.254+0800 I CONTROL [initandlisten]
2017-08-30T00:02:33.254+0800 I CONTROL [initandlisten] ** WARNING: Access control is not enabled for the database.
2017-08-30T00:02:33.254+0800 I CONTROL [initandlisten] ** Read and write access to data and configuration is unrestricted.
2017-08-30T00:02:33.254+0800 I CONTROL [initandlisten]
2017-08-30T00:02:33.254+0800 I CONTROL [initandlisten]
2017-08-30T00:02:33.254+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
2017-08-30T00:02:33.254+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2017-08-30T00:02:33.254+0800 I CONTROL [initandlisten]
2017-08-30T00:02:33.254+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
2017-08-30T00:02:33.254+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2017-08-30T00:02:33.255+0800 I CONTROL [initandlisten]
>
成功进入,MongoDB安装完毕
用Node.js操作MongoDB
安装node的mongodb模块
# npm install -g mongodb
在需要运行的目录下链接模块
# npm link mongodb
MongoDB权限配置
编辑配置文件目录
# vim /etc/mongod.conf
设置mongodb配置中的auth为true:
security:
authorization: enabled
建立新用户(以root用户为例)
> use admin
switched to db admin
> db.createUser( { user: "rootname", pwd: "password", roles: [ { role: "root", db: "admin" } ] })
Successfully added user: {
"user" : "rootname",
"roles" : [
{
"role" : "root",
"db" : "admin"
}
]
}
rootname和password分别表示数据库的用户名和用户密码,role: "root"表示数据库的用户角色,db: "admin"表示这个用户建立在数据库“admin”中。
注意:帐号跟着库走,在指定库里授权,必须也在指定库里验证(auth)
重启服务,使开启验证生效
#systemctl restart mongod.service
再次登录mongo然后进行操作会提示需要验证
# mongo
MongoDB shell version v3.4.7
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.4.7
> show dbs
2017-08-31T17:06:50.833+0800 E QUERY [thread1] Error: listDatabases failed:{
"ok" : 0,
"errmsg" : "not authorized on admin to execute command { listDatabases: 1.0 }",
"code" : 13,
"codeName" : "Unauthorized"
} :
_getErrorWithCode@src/mongo/shell/utils.js:25:13
Mongo.prototype.getDBs@src/mongo/shell/mongo.js:62:1
shellHelper.show@src/mongo/shell/utils.js:769:19
shellHelper@src/mongo/shell/utils.js:659:15
@(shellhelp2):1:1
选择库然后登录,就有权限了
> use admin
switched to db admin
> db.auth('rootname','passward')
1
> show dbs
admin 0.000GB
local 0.000GB
超级管理员权限配置完毕
查看更多配置可以参考官方文档