操作環(huán)境
服務器:阿里云 CentOS7.3.1611
時間: 20170818
安裝Git
阿里云更換了系統(tǒng)盤,不小心手賤腌歉,順手更新到最新系統(tǒng)
# yum update
再順手重啟下
#reboot
然后再次遠程登錄上服務器秕磷,看下系統(tǒng)版本
# 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撞叨,貌似提示為不穩(wěn)定版厕九?
# 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
測試是否已經(jīng)可用
# 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揩徊,可以看到網(wǎng)頁頁面輸出 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
從官網(wǎng)獲得社區(qū)版下載地址,選擇平臺為Linux塑荒,Version 選擇為 RHEL 7 Linux 64-bit x64熄赡,這里沒有CentOS,所以只能選RHEL齿税,反正也差不多彼硫。點擊下方的Package Manager:Instructions for installing with yum,進入說明文檔凌箕。
根據(jù)上面的官方說明拧篮,新建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
數(shù)據(jù)文件在:/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權(quán)限配置
編輯配置文件目錄
# 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分別表示數(shù)據(jù)庫的用戶名和用戶密碼,role: "root"表示數(shù)據(jù)庫的用戶角色慧妄,db: "admin"表示這個用戶建立在數(shù)據(jù)庫“admin”中顷牌。
注意:帳號跟著庫走,在指定庫里授權(quán)塞淹,必須也在指定庫里驗證(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
選擇庫然后登錄,就有權(quán)限了
> use admin
switched to db admin
> db.auth('rootname','passward')
1
> show dbs
admin 0.000GB
local 0.000GB
超級管理員權(quán)限配置完畢
查看更多配置可以參考官方文檔