专栏首页流浪猫的golangmongodb 学习随笔 及golang 连接mongoDB

mongodb 学习随笔 及golang 连接mongoDB

Mogondb 不支持事务。所有有事务要求的需求慎用,比如银行的转账操作慎用,转1个亿美金,因为网络,电力的故障导致交易没有完成,不能回滚,交易无法撤回。所有慎用!!

Mogondb 的应用场景: 比如一篇CSDN博客,博客内容,博客作者,发布时间,评论,阅读量等信息可以将这些信息存储到一个类似JSON数据中。如果用mysql需要将不同的信息分别存储于不同的表中,使用的时候,查询多表或者使用JOIN查询数据,导致查询过慢。而使用MongoDB,将数据存储在一起,需要数据时,一次就能查询到数据。更新数据或者添加数据可以在原有的数据集上直接更新或者添加,很方便。

MongoDB易于管理,更新数据,可以不用像传统的关系型数据使用JOIN来进行查询,提高性能。

Mogodb扩展起来很容易,可以在多台服务器进行部署。而且对于大数据,对于csdn博客的系统来讲,每一天,每一个月,每一年都有大量的博客被写出来,数据量的增长每年都是很大的,mongoDB可以在不停机的情况下进行弹性扩展, 意思是增加上几台存储的服务器,形成分布式存储。 MongoDB很适合于这种需求场景的,不知道csdn怎么实现的 ?

MongoDB 还能高效存储二进制大对象,比如照片,音乐,视频的存储,庞大的数据还能加索引和实时聚合

mongodb将数据存储在灵活的类似json的文档中,字段结构可能因文档而异,数据结构可随时改变 Json模型可以映射到应用程序代码中的对象,这样就很方便的进行使用,有orm的感觉。 在golang中就可以直接与结构体关联起来。

类似json的文档数据结构叫做BSON,比json最突出的好处是BSON可遍历。

MongoDB支持二维空间索引,使用空间索引,mongoDB支持一种特殊查询,如某地图网站上可以查找离你最近的咖啡厅,银行等信息。这个使用mongoDB的空间索引结合特殊的查询方法很容易实现。

滴滴、膜拜、OFO等基于位置进行查询的场景都可以使用MongoDB的位置索引。

golang 连接mongodb

golang 没有官方mongodb驱动,但是有社区的驱动:http://labix.org/mgo 第一步:连接mongodb

package main

import (
    "gopkg.in/mgo.v2"
    "fmt"
)
func main() {
    session, err := mgo.Dial("mongodb://123.207.215.200:27017")
    defer session.Close()
    if err !=nil {
        fmt.Println(err)
        return
    }
    names,err:=session.DatabaseNames();
    if err !=nil {
        fmt.Println("未查询到数据库名字:",err)
    }
    fmt.Println(names)
}

运行结果:

[local mytest]

其他url的拼接规则: mongodb://[username:password@]host1[:port1][,host2[:port2],…[,hostN[:portN]]][/[database][?options]] mongodb:// 这是固定的格式,必须要指定。

username:password@ 可选项,如果设置,在连接数据库服务器之后,驱动都会尝试登陆这个数据库 host1 必须的指定至少一个host, host1 是这个URI唯一要填写的。它指定了要连接服务器的地址。如果要连接复制集,请指定多个主机地址。 portX 可选的指定端口,如果不填,默认为27017 /database 如果指定username:password@,连接并验证登陆指定数据库。若不指定,默认打开 test 数据库。 ?options 是连接选项。如果不使用/database,则前面需要加上/。所有连接选项都是键值对name=value,键值对之间通过&或;(分号)隔开 参考菜鸟教程或者官方文档都可以: http://www.runoob.com/mongodb/mongodb-connections.html https://docs.mongodb.com/manual/reference/connection-string/index.html

附加一: windows 工具 连接mongodb的方式,如果用代码连接mongodb,发生错误,可以用工具检查服务是否能正常被连接。 (一).安装windows mongodb,略。 (二).使用命令行的进入mongodb 安装目录中bin目录中,执行

C:\Program Files\MongoDB\Server\3.6\bin>mongo 123.207.215.200:27017

需要注意的是 此时的url 没有”mongodb://”

linux的方式类似:

root@VM-192-98-ubuntu:/usr/local/mongodb/bin# ./mongo 127.0.0.1

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • golang mutex锁的竞争关系浅析

    刚才对golang的锁关系进行 一番思索,想着协程获取golang 对象锁的,是按先按时间先后顺序获取的,其实不然。下面请看代码,顺带写了2种读写锁的应用。

    地球流浪猫
  • go test 使用全教程

    golang 中的go test 为golang 软件包提供了一种单元测试方式,非常简单的同时也非常好用。 ok 先来看看怎么用? 1. 新建go 文件...

    地球流浪猫
  • linux 下 nginx 安装echo扩展模块

    echo 模块可以将nginx 变量的信息输出到网页中。echo 模块对学习nginx 配置文件有很大帮助,对应调试nginx 配置文件中变量特步方便。想要深...

    地球流浪猫
  • mac环境下mongodb的安装和使用

    简介 MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 MongoDB 是一个介于关系数据...

    xiangzhihong
  • mac环境下mongodb的安装和使用

    简介 MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 MongoDB 是一个介于关系数据...

    xiangzhihong
  • mongodb11天之屠龙宝刀(二)安装与配置 :MongoDB 与使用 IDE

    mongodb11天之屠龙宝刀(二)安装与配置 :MongoDB 与使用 IDE System environments 原文连接:直通车 - windo...

    学到老
  • 在腾讯云主机中Centos7 设置Mongodb开机启动-自定义服务

    这两天在跟着全栈之巅的视频学习NodeJs+Express+MongoDB编写相关的项目时,发现在Windows下安装MongoDB很顺利,将MongoDB安装...

    ccf19881030
  • MongoDB安装笔记

    ihoey
  • Linux安装Mongodb教程

    官网下载地址:https://www.mongodb.com/download-center/community

    华创信息技术
  • centos安装mongodb 4.x及配置用户名密码(官方推荐的方式)

    先在本地用记事本做一个这样的文件(命名为:mongodb-org-4.0.repo):

    liulun

扫码关注云+社区

领取腾讯云代金券