首页 > 数据库 >本地主机连接Linux虚拟机中的mongodb,并使用studio 3T连接,同时项目启动连接mongodb刷新数据库

本地主机连接Linux虚拟机中的mongodb,并使用studio 3T连接,同时项目启动连接mongodb刷新数据库

时间:2024-03-23 12:59:24浏览次数:37  
标签:mongodb 虚拟机 firewalld zhouyu usr firstwork data 连接

本部分只做个人纪录

**

1.安装mongodb

**
本部分为尚硅谷的电影推荐系统的文档,具体以实际存放位置为准

// 通过WGET下载Linux版本的MongoDB
[bigdata@linux ~]$ wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel62-3.4.3.tgz

// 将压缩包解压到指定目录
[bigdata@linux backup]$ tar -xf mongodb-linux-x86_64-rhel62-3.4.3.tgz -C ~/

// 将解压后的文件移动到最终的安装目录
[bigdata@linux ~]$ mv mongodb-linux-x86_64-rhel62-3.4.3/ /usr/local/mongodb

// 在安装目录下创建data文件夹用于存放数据和日志
[bigdata@linux mongodb]$ mkdir /usr/local/mongodb/data/

// 在data文件夹下创建db文件夹,用于存放数据
[bigdata@linux mongodb]$ mkdir /usr/local/mongodb/data/db/

// 在data文件夹下创建logs文件夹,用于存放日志
[bigdata@linux mongodb]$ mkdir /usr/local/mongodb/data/logs/

// 在logs文件夹下创建log文件
[bigdata@linux mongodb]$ touch /usr/local/mongodb/data/logs/ mongodb.log

// 在data文件夹下创建mongodb.conf配置文件
[bigdata@linux mongodb]$ touch /usr/local/mongodb/data/mongodb.conf

// 在mongodb.conf文件中输入如下内容
[bigdata@linux mongodb]$ vim ./data/mongodb.conf
#端口号port = 27017
#数据目录
dbpath = /usr/local/mongodb/data/db
#日志目录
logpath = /usr/local/mongodb/data/logs/mongodb.log
#设置后台运行
fork = true
#日志输出方式
logappend = true
#开启认证
#auth = true



// 启动MongoDB服务器
[bigdata@linux mongodb]$ sudo /usr/local/mongodb/bin/mongod -config /usr/local/mongodb/data/mongodb.conf
// 访问MongoDB服务器
[bigdata@linux mongodb]$ /usr/local/mongodb/bin/mongo
// 停止MongoDB服务器
[bigdata@linux mongodb]$ sudo /usr/local/mongodb/bin/mongod -shutdown -config /usr/local/mongodb/data/mongodb.conf

其中,本地的虚拟机没有按照文档的内容

2.启动部分如下

,注意,具体地址按照自己的情况来,不知道地址的可以看mongodb.conf文件的path配置,或者定位到bin目录使用pwd命令查看地址

   [zhouyu@firstwork ~]$ sudo /home/zhouyu/mongodb/bin/mongod -config /home/zhouyu/mongodb/data/mongodb.conf
   
    

,再或者cd多次直到bin的上级目录,使用

[ zhouyu@firstwork  mongodb]$ sudo bin/mongod -config   ./data/mongodb.conf

总之这种启动方式注意mongodb.conf和bin目录就行,把握这两个就万变不离其宗了

然后是访问MongoDB服务器:

[zhouyu@firstwork ~]$ cd mongodb/
[zhouyu@firstwork mongodb]$ bin/mongod -config ./data/mongodb.conf 
about to fork child process, waiting until server is ready for connections.
forked process: 2828
child process started successfully, parent exiting
[zhouyu@firstwork mongodb]$ jps
2923 Jps
[zhouyu@firstwork mongodb]$ ps -ef | grep mongo
zhouyu     2828      1  0 18:01 ?        00:00:02 bin/mongod -config ./data/mongodb.conf
zhouyu     2958   2719  0 18:08 pts/0    00:00:00 grep --color=auto mongo
[zhouyu@firstwork mongodb]$ bin/mongo
MongoDB shell version v3.4.3
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.4.3
Server has startup warnings: 
2024-03-20T18:01:04.145+0800 I CONTROL  [initandlisten] 
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] ** WARNING: Access control is not enabled for the database.
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] **          Read and write access to data and configuration is unrestricted.
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] 
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] 
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] **        We suggest setting it to 'never'
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] 
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] **        We suggest setting it to 'never'
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] 
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] ** WARNING: soft rlimits too low. rlimits set to 2048 processes, 65536 files. Number of processes should be at least 32768 : 0.5 times number of files.
2024-03-20T18:01:04.146+0800 I CONTROL  [initandlisten] 
> show dbs
admin  0.000GB
local  0.000GB

在Linux的火狐浏览器中访问 http://192.168.220.131:27017/ 可得如下内容:这是
由于mongodb不支持http请求的原因,不必介意,可以视为虚拟机内部可以访问mongodb了
在这里插入图片描述
如果你不知道ip,使用ifconfig命令即可知道,那个ensxxx的inet就是你的ip,端口号默认是
27017,除非你要指定了,不然默认即可

[zhouyu@firstwork ~]$ ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.220.131  netmask 255.255.255.0  broadcast 192.168.220.255
        inet6 fe80::257a:5178:2031:5aab  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:c8:52:c1  txqueuelen 1000  (Ethernet)
        RX packets 31184  bytes 13846558 (13.2 MiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 8065  bytes 1695812 (1.6 MiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 360  bytes 33822 (33.0 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 360  bytes 33822 (33.0 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

virbr0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
        inet 192.168.122.1  netmask 255.255.255.0  broadcast 192.168.122.255
        ether 52:54:00:1d:cd:84  txqueuelen 1000  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

有用信息:

      inet 192.168.220.131     ip地址
      netmask 255.255.255.0 子网掩码
      broadcast 192.168.220.255 广播地址

但是问题是在外部浏览器无法访问,这里就需要考虑两个问题
第一是防火墙的问题

[zhouyu@firstwork ~]$ su root
密码:
[root@firstwork zhouyu]# systemctl status firewalld 
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; enabled; vendor preset: enabled)
   Active: active (running) since 三 2024-03-20 19:52:34 CST; 2h 11min ago
     Docs: man:firewalld(1)
 Main PID: 773 (firewalld)
    Tasks: 2
   CGroup: /system.slice/firewalld.service
           └─773 /usr/bin/python2 -Es /usr/sbin/firewalld --nofork --nopid

3月 20 19:52:34 firstwork systemd[1]: Starting firewalld - dynamic firewal.....
3月 20 19:52:34 firstwork systemd[1]: Started firewalld - dynamic firewall...n.
3月 20 19:52:35 firstwork firewalld[773]: WARNING: AllowZoneDrifting is ena....
Hint: Some lines were ellipsized, use -l to show in full.
[root@firstwork zhouyu]# systemctl stop firewalld.service
[root@firstwork zhouyu]# systemctl status firewalld 
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; enabled; vendor preset: enabled)
   Active: inactive (dead) since 三 2024-03-20 22:04:31 CST; 5s ago
     Docs: man:firewalld(1)
  Process: 773 ExecStart=/usr/sbin/firewalld --nofork --nopid $FIREWALLD_ARGS (code=exited, status=0/SUCCESS)
 Main PID: 773 (code=exited, status=0/SUCCESS)

3月 20 19:52:34 firstwork systemd[1]: Starting firewalld - dynamic firewal.....
3月 20 19:52:34 firstwork systemd[1]: Started firewalld - dynamic firewall...n.
3月 20 19:52:35 firstwork firewalld[773]: WARNING: AllowZoneDrifting is ena....
3月 20 22:04:30 firstwork systemd[1]: Stopping firewalld - dynamic firewal.....
3月 20 22:04:31 firstwork systemd[1]: Stopped firewalld - dynamic firewall...n.
Hint: Some lines were ellipsized, use -l to show in full.
[root@firstwork zhouyu]# exit

有三点注意:
1.有些命令需要确定是不是在root下进行,防火墙的命令是需要切换的
切换root 使用 su root即可
2. systemctl status firewalld 是查看状态 systemctl stop firewalld.service 是停用,不过只是单次这意味着如果你重启后该命令就失效了,防火墙仍然开启,我就吃亏在这上面 systemctl enable firewalld.service 开启开机启动 systemctl disable firewalld.service 关闭开机启动 :
3.用完root后记得exit切换会普通用户

第二是修改mongod.conf文件,还记得前面的配置吗
在这里插入图片描述

我们需要加点东西
在这里插入图片描述
如果是这种,写bind_ip即可,如果是yaml格式
在这里插入图片描述这种就需要按照驼峰规则了

查看到conf文件过程:

[zhouyu@firstwork mongodb]$ cd data
[zhouyu@firstwork data]$ ls
db  logs  mongodb.conf
[zhouyu@firstwork data]$ cd mongodb.conf
bash: cd: mongodb.conf: 不是目录
[zhouyu@firstwork data]$ vim mongodb.conf 

之前我们只是在虚拟机内部的浏览器查看,现在我们可以在外部,访问虚拟机了

在使用studio 3T连接之前
在外部的浏览器使用之前在火狐的ip:端口号如法炮制,如果得到相同内容,则说明可以尝试了
在这里插入图片描述
这里还需要提醒一点,我的auth=true是关闭的,就是说没开启认证,我不清楚开启认证对于后面连接的是否需要连接ssh部分有影响,这里提醒一下,后期有机会补充
在这里插入图片描述

我使用的是studio 3T,下载不赘述

在这里插入图片描述
选下面的
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
输入后点击测试,成功后点击ok->save即可
在这里插入图片描述
如果右侧没有这些,则直接退出重进一般会有
点击运行scala,连接mongodb数据库
在这里插入图片描述
出现相关内容
在这里插入图片描述
至此成功
总之,该部分写的过程我查了一些资料,可惜没有完整走一遍,都是东拼西凑。我自己也纪录的不详细,时间仓促,只能写出来这点东西了。希望可以给别人一些帮助吧。
我看csdn有些东西还要收费或者开会员。这帮人拿着不知道转了几手的东西居然还想收费?能不能有点开源精神?

标签:mongodb,虚拟机,firewalld,zhouyu,usr,firstwork,data,连接
From: https://blog.csdn.net/weixin_44628096/article/details/136892251

相关文章

  • VMWare17.5.0版本避坑,安装虚拟机后按下键盘和鼠标,界面会卡死
    问题描述在使用VMWare17.5.0版本安装ubuntu22.0.4.4的时候遇到问题。安装完成ubuntu之后,我在虚拟机中点击鼠标左键没有问题,单独按下键盘也没有问题,但是如果按下键盘的同时在按下鼠标左键就会卡住。而且100%稳定复现。具体的卡死按键:ctrl+鼠标左键alt+鼠标左键其实并不是真......
  • 利用termux和qemu虚拟机使用docker
    操作前提由于大部分手机的内核并不满足使用docker的要求,因此需要用root权限修改手机部分kernel来满足,但是手机root并不适用所有手机,而且root也有一定的风险,因此使用termux终端来通过qemu虚拟机进行容器化操作可以实现满足docker运行的要求。操作步骤安装termux或者zerotermux......
  • 多开随机硬件防封过检测VM虚拟机过鲁大师 NP,HP,VMP,SE,TMD,WL,ENIGMA,SP等检测。
    网上各种虚拟机过检测多开,这些都是吹的天花乱坠,但是卖的虚拟机只是一个硬件复制多台,这样多开稳死,过检测也无济于事。我们的随机硬件虚拟机就是解决了这个痛点,每个新建立的虚拟机都是不同硬件达到多开更稳更安心的程度,这款多开虚拟机是win7/win10高帧版本,流畅自如。支持很多游戏......
  • 09 事务和连接池
    文章目录properties文件连接池service层实现类dao层实现类dao层实现类连接池类:创建线程池静态常量,用于放连接。创建Properties静态常量,用于解析properties文件静态代码块中,解析properties文件,将解析结果用于创建连接池连接方法:用线程获取连接,若没有,从连接池......
  • jmeter 多接口之间,token连接
    接口名称接口类型URL参数    银行登录接口2(token)POST/pinter/bank/api/login2userName=admin&password=1234    银行余额查询接口(token)GET/pinter/bank/api/query2userName=admin接口一:登录接口,post请求,url地址:/pinter/bank/api/login2,参......
  • 2020-8-6-JVM虚拟机
    运行时数据区域、溢出、垃圾收集、问题解决运行时数据区域Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域1)程序计数器(1)一块较小的内存空间,它可以看作是当前线程所执行的字节码的行号指示器(2)字节码解释器工作时就是通过改变这个计数器的......
  • 2020-2-17-mongodb的使用
    下载地址、安装、启动服务、查看、创建数据库及表、新增数据、删除数据、更新数据、查询数据、索引下载地址http://dl.mongodb.org/dl/win32/x86_64下载名为mongodb-win32-x86_64-2012plus-v4.2-latest-signed.msi的文件安装点击下一步,跳过安装mangodb_compass启动服务mo......
  • mysql 连接出现 Public Key Retrieval is not allowed
    在MySQL连接中出现“PublicKeyRetrievalisnotallowed”错误,通常是因为在使用安全套接字层(SSL)连接时遇到了问题。这是因为MySQL8.0及以上版本对安全性要求更高,特别是在使用密码插件如caching_sha2_password时,默认要求加密通信,并且不允许通过不安全的方式获取服务器的公钥。......
  • 树莓派无屏幕无网线直接连接电脑
    首先通过连接的wifi,查到树莓派的地址,在电脑里找远程桌面连接输入地址,连接如果连接不上,则需要通过putty在树莓派上下载xrdp打开putty,输入地址输入账号密码输入sudoapt-getinstallxrdp回车 中间会停一下,问是否继续,继续回车等待安装完成完成后,在远程桌面连接输......
  • 使用 langchain 连接 通义千问 并用 fastApi 开放接口
    安装langchain方法https://www.cnblogs.com/hailexuexi/p/18087602安装fastapifastapi 是一个用于构建高性能Web应用的Python框架,它提供了简洁、高效的API开发体验。pipinstallfastapi 安装uvicornuvicorn 是一个用于运行 FastAPI 应用的服务器,它可以将......