MONGDB
安装与使用
咱们来回顾一下上次分享的内容:
- 如何使用
log
包 log
包原理和具体实现- 自定义日志
要是对 GO 的日志包还有点兴趣的话,可以查看文章 GO的日志怎么玩 ?
今天咱们来玩个简单的 mongodb
的安装和使用
MONGODB
介绍
MongoDB
是一个基于分布式文件存储的数据库使用
C++
语言编写
MongoDB
主要是 为WEB应用提供可扩展的高性能数据存储解决方案
是非关系数据库当中功能最丰富,它支持的数据结构非常松散,是类似 JSON
的 BSON
格式的
MONGODB
的语法有点类似于面向对象的查询语言,咱们用起来也是很简单的
mongodb
安装
下载mongodb
安装包
网址:www.mongodb.com/try/downloa...
官网上可以下载多个系统的mongdb
安装包,windows
,centos
,ubuntu
等等,如图
根据页面上的内容,咱们可以选择不同版本的,按需索取,默认咱们就做吃螃蟹的人吧,直接上最新的
安装MONGODB
软件
解压mongodb
压缩包
tar xvf mongodb-linux-x86_64-rhel80-4.4.4.tgz
将解压生成的目录 改名为mongodb
,并移动到 /usr/local
下
mv mongodb-linux-x86_64-rhel80-4.4.4.tgz mongodb
mv mongodb /usr/local/
进入mongodb
目录下
- 创建data目录
- data目录下创建db目录
- data目录下创建log目录
mkdir data
cd data
mkdir db
mkdir log
回到mongo
目录下,创建mongodb
的配置文件,mongodb.conf
,之后启动需要用到
需要在mongodb.conf
下配置
- dbpath
数据库的数据存放位置
- logpath
日志文件存放位置
- logappend
日志是否以追加的方式
- port
端口号
- auth
是否需要认证
- fork
是否以守护进程的方式运行
- bind
限制远程访问的ip
,不做限制的话可以写0.0.0.0
dbpath=/usr/local/mongodb/data/db
logpath=/usr/local/mongodb/data/log/mongodb.log
logappend=true
port=27017
auth=true
fork=true
bind_ip=0.0.0.0
将mongodb
可执行程序写入到/etc/profile 中,开机时会自动读取这个文件
export MONGODB_HOME=/usr/local/mongodb
export PATH=$PATH:$MONGODB_HOME/bin
启动mongodb
服务
mongod -f /usr/local/mongodb/mongodb.conf
关于防火墙
- 可以直接关闭系统的防火墙平时
- 防火墙打开端口27017端口,以便于客户端进行连接mongdb
关于MONGODB
的状态查看
查询mongodb
状态
ps aux |grep mongodb
查看端口
netstat -antp |grep 27017
关闭mongodb
有如下两种操作,随你选,喜欢啥用啥
- 通过kill 命令杀掉
PID
即可 mongod -f /usr/local/mongodb/mongodb.conf --shutdown
mongodb
设置角色、用户名、密码
/usr/local/mongodb/mongodb.conf
的配置如下,我们可以吧auth
置为false
,auth
字段开启,是开启认证,关闭则是关闭认证
mongodb
有多个角色
角色 | |
---|---|
用户 | read、readWrite |
管理员 | dbAdmin、dbOwner、userAdmin |
集群管理员 | clusterAdmin、clusterManager、clusterMonitor、hostManager |
备份恢复权限 | backup、restore |
所有数据库权限 | readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase |
超级用户 | root |
内部角色 | __system |
mongodb
数据库的使用
选择数据库
use xxx
创建管理员账号
db.createUser({user:'admin2',pwd:'123456',roles:[{role:'readWriteAnyDatabase',db:'admin'}]})
AnyDatabase',db:'admin'}]})
执行后,如下效果
Successfully added user: {
"user" : "admin2",
"roles" : [
{
"role" : "readWriteAnyDatabase",
"db" : "admin"
}
]
}
接下来具体的mongodb
数据库操作,可以看菜鸟教程学习一波,很快就会用了
mongodb
设置开机启动
- 添加一个
mongodb
的服务 到init.d
中
vim /etc/rc.d/init.d/mongod
- 编写这个服务的具体实现
start() {
/usr/local/mongodb/bin/mongod --config /usr/local/mongodb/mongodb.conf
}
stop() {
/usr/local/mongodb/bin/mongod --config /usr/local/mongodb/mongodb.conf --shutdown
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
stop
start
;;
*)
echo $"details: $0 {start|stop|restart}"
exit 1
esac
-
对这个服务的可执行程序添加执行权限
chmod +x /etc/rc.d/init.d/mongod
-
启动
mongod
service mongod start
-
关闭
mongod
service mongod stop
-
重启
mongod
service mongod restart
可视化工具
介绍一个可视化工具,非常好用,比nosql
这个工具好用多了
Robo 3T 1.3.1 下载链接如下
软件操作比较简单,大家下载下来后,熟悉一下界面,就会使用了。
GOLANG
简单操作mongodb
mongodb
的驱动大家使用比较多的有2种:
mongodb
官方的库,go.mongodb.org/mongo-driver/mongo
- 第三方库
gopkg.in/mgo.v2
地址为:labix.org/mgo
我们选用官方的驱动库来介绍mongdb
简单的
- 增
- 删
- 改
type Test struct {
Name string `bson:"name"`
Age int `bson:"age"`
CreateTime int64 `bson:"createTime"`
UpdateTime int64 `bson:"updateTime"`
}
func initMongdb() error {
// 1 建立mongodb连接
// 填写自己的mongdb地址,端口默认是 27017
clientOptions := options.Client().ApplyURI("mongodb://admin:123456@xxxx:27017/admin?authMechanism=SCRAM-SHA-1")
mclient, err := mongo.Connect(context.TODO(), clientOptions)
if err != nil {
mlog.Error(err)
return err
}
// 2, 选择数据库my_db
database := mclient.Database("admin")
// 3, 选择表my_collection
collection := mgMongoDatabase.Collection("deviceToken")
mlog.Info("connect mongdb successfully")
// 插入数据
record := &Test{
Name: "小魔童",
CreateTime: time.Now().Unix(),
UpdateTime: time.Now().Unix(),
}
result, err := collection.InsertOne(context.TODO(), record)
if err != nil {
mlog.Error(err)
return err
}
mlog.Info(result)
// 更新数据
// if err := UpdateData(bson.M{"name": "xxxx"}, bson.D{{"$set", bson.M{"age": 15}}}); err != nil {
// mlog.Error(err)
// return
// }
//查询单个记录
//data := &DeviceToken{}
//err = collection.FindOne(context.TODO(),bson.M{}).Decode(data)
//mlog.Info(data)
//查询所有记录
data := []DeviceToken{}
cursor, err := collection.Find(context.TODO(), bson.M{})
cursor.All(context.TODO(), &data)
mlog.Info(data)
// 删除一条记录
//res ,err := mgMongoCollection.DeleteOne(context.TODO(),bson.M{"name":"xxxx"})
//if err != nil{
// mlog.Warn(err)
//}
return nil
}
感兴趣的 XDM 可以多多实践,将上述代码贴到自己的环境查看效果,上述主要讲了如下几个操作:
- 连接
mongodb
数据库 - 选择对应 库, 和 表
- 插入一条数据 / 插入多条数据
- 更新一条数据 / 插入多条数据
- 查询新一条数据 / 插入多条数据
- 删除新一条数据 / 插入多条数据
对应数据库的基本应用还是非常简单的,但是我们会应用之后,一定要去细细品味其中的原理,官方 或者是第三方包是如何实现的,我们自己是否可以自己写一个版本
感兴趣的小伙伴,可以尝试深入一下
总结
- mongodb 的介绍
- mongodb 如何安装
- mongodb 如何简单使用
- GO 如何操作 mongodb