热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Linux系统下安装配置MongoDB过程详解

MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。下面详细讲解安装步骤。1.下载(二进制版本免安装)#wgethttp://fastdl.mongodb.org/linux/mongodb-linux-x86_64-1.8.1.tgz#tarzxvfm
MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。下面详细讲解安装步骤。

1.下载(二进制版本免安装)
# wget http://fastdl.mongodb.org/linux/mongodb-linux-x86_64-1.8.1.tgz
# tar zxvf mongodb-linux-x86_64-1.8.1.tgz -C /usr/local

2.配置
# useradd mongod ?s /sbin/nologin
# mkdir /www/data/mongo
# mkdir /var/log/mongo
# chown mongod.mongod /www/data/mongo
# chown mongod.mongod /var/log/mongo
# mkdir /usr/local/mongodb-linux-x86_64-1.8.1/etc
# cd /usr/local/mongodb-linux-x86_64-1.8.1/etc
# vim mongod.conf
# mongo.conf
#where to log
logpath=/var/log/mongo/mongod.log
logappend=true
# fork and run in background
fork = true
#port = 27017
dbpath=/www/data/mongo
# Enables periodic logging of CPU utilization and I/O wait
#cpu = true
# Turn on/off security. Off is currently the default
#noauth = true
#auth = true
# Verbose logging output.
#verbose = true
# Inspect all client data for validity on receipt (useful for
# developing drivers)
#objcheck = true
# Enable db quota management
#quota = true
# Set oplogging level where n is
# 0=off (default)
# 1=W
# 2=R
# 3=both
# 7=W+some reads
#oplog = 0
# Diagnostic/debugging option
#nocursors = true
# Ignore query hints
#nohints = true
# Disable the HTTP interface (Defaults to localhost:27018).
#nohttpinterface = true
# Turns off server-side scripting. This will result in greatly limited
# functionality
#noscripting = true
# Turns off table scans. Any query that would do a table scan fails.
#notablescan = true
# Disable data file preallocation.
#noprealloc = true
# Specify .ns file size for new databases.
# nssize =
# Accout token for Mongo monitoring server.
#mms-token =
# Server name for Mongo monitoring server.
#mms-name =
# Ping interval for Mongo monitoring server.
#mms-interval =
# Replication Options
# in replicated mongo databases, specify here whether this is a slave or master
#slave = true
#source = master.example.com
# Slave only: specify a single database to replicate
#Only= master.example.com
# or
#master = true
#source = slave.example.com

3.启动mongod
# /usr/local/mongodb-linux-x86_64-1.8.1/bin/mongod -f /usr/local/mongodb-linux-x86_64-1.8.1/etc/mongod.conf

4.自启动脚本
# vim /etc/init.d/mongod
#!/bin/bash
# mongod - Startup script for mongod
# chkconfig: 35 85 15
# description: Mongo is a scalable, document-oriented database.
# processname: mongod
. /etc/rc.d/init.d/functions
# things from mongod.conf get there by mongod reading it
OPTIOnS=" -f /usr/local/mongodb-linux-x86_64-1.8.1/etc/mongod.conf"
SYSCOnFIG="/etc/sysconfig/mongod"
mOngod="/usr/local/mongodb-linux-x86_64-1.8.1/bin/mongod"
MONGO_USER=mongod
MONGO_GROUP=mongod
. "$SYSCONFIG" || true
start()
{
echo -n $"Starting mongod: "
daemon --user "$MONGO_USER" $mongod $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/mongod
}
stop()
{
echo -n $"Stopping mongod: "
killproc -p /www/data/mongo/mongod.lock -t30 -TERM $mongod
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/mongod
}
restart () {
stop
start
}
ulimit -n 12000
RETVAL=0
case "$1" in
start)
start
;;
stop)
stop
;;
restart|reload|force-reload)
restart
;;
condrestart)
[ -f /var/lock/subsys/mongod ] && restart || :
;;
status)
status $mongod
RETVAL=$?
;;
*)
echo "Usage: $0 {start|stop|status|restart|reload|force-reload|condrestart}"
RETVAL=1
esac
exit $RETVAL

# chmod +x /etc/init.d/mongod
# chkconfig ?add mongod
# chkconfig mongod on
# service mongod restart

日志信息如下:
Sat May 7 14:40:55 got kill or ctrl c or hup signal 15 (Terminated), will terminate after current cmd ends
Sat May 7 14:40:55 [interruptThread] now exiting
Sat May 7 14:40:55 dbexit:
Sat May 7 14:40:55 [interruptThread] shutdown: going to close listening sockets...
Sat May 7 14:40:55 [interruptThread] closing listening socket: 5
Sat May 7 14:40:55 [interruptThread] closing listening socket: 6
Sat May 7 14:40:55 [interruptThread] closing listening socket: 7
Sat May 7 14:40:55 [interruptThread] closing listening socket: 8
Sat May 7 14:40:55 [interruptThread] removing socket file: /tmp/mongodb-27017.sock
Sat May 7 14:40:55 [interruptThread] removing socket file: /tmp/mongodb-28017.sock
Sat May 7 14:40:55 [interruptThread] shutdown: going to flush diaglog...
Sat May 7 14:40:55 [interruptThread] shutdown: going to close sockets...
Sat May 7 14:40:55 [interruptThread] shutdown: waiting for fs preallocator...
Sat May 7 14:40:55 [interruptThread] shutdown: closing all files...
Sat May 7 14:40:55 closeAllFiles() finished
Sat May 7 14:40:55 [interruptThread] shutdown: removing fs lock...
Sat May 7 14:40:55 dbexit: really exiting now
Sat May 7 14:40:55 [initandlisten] MongoDB starting : pid=20495 port=27017 dbpath=/www/data/mongo 64-bit
Sat May 7 14:40:55 [initandlisten] db version v1.8.1, pdfile version 4.5
Sat May 7 14:40:55 [initandlisten] git version: a429cd4f535b2499cc4130b06ff7c26f41c00f04
Sat May 7 14:40:55 [initandlisten] build sys info: Linux bs-linux64.10gen.cc 2.6.21.7-2.ec2.v1.2.fc8xen #1 SMP Fri Nov 20 17:48:28 EST 2009 x86_64 BOOST_LIB_VERSION=1_41
Sat May 7 14:40:55 [initandlisten] waiting for connections on port 27017
Sat May 7 14:40:55 [websvr] web admin interface listening on port 28017

5.查看端口
# netstat -nptl | grep mongod
tcp 0 0 0.0.0.0:27017 0.0.0.0:* LISTEN 20495/mongod
tcp 0 0 0.0.0.0:2801 0.0.0.0:* LISTEN 20495/mongod

6.web界面
http://localhost:28017

7.登录
Mongo是mongodb自带的交互式Javascript shell,用来对mongod进行操作和管理的交互式环境。
# /usr/local/mongodb-linux-x86_64-1.8.1/bin/mongo
注意:MongoDB服务端可运行在Linux、Windows或OS X平台,支持32位和64位应用,默认端口为27017。推荐运行在64位平台,因为MongoDB在32位模式运行时支持的最大文件尺寸为2GB。

推荐阅读
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文探讨了MariaDB在当前数据库市场中的地位和挑战,分析其可能面临的困境,并提出了对未来发展的几点看法。 ... [详细]
  • 本文详细介绍了Python编程语言的学习路径,涵盖基础语法、常用组件、开发工具、数据库管理、Web服务开发、大数据分析、人工智能、爬虫开发及办公自动化等多个方向。通过系统化的学习计划,帮助初学者快速掌握Python的核心技能。 ... [详细]
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
  • 云计算的优势与应用场景
    本文详细探讨了云计算为企业和个人带来的多种优势,包括成本节约、安全性提升、灵活性增强等。同时介绍了云计算的五大核心特点,并结合实际案例进行分析。 ... [详细]
  • 基于Node.js、Express、MongoDB和Socket.io的实时聊天应用开发
    本文详细介绍了使用Node.js、Express、MongoDB和Socket.io构建的实时聊天应用程序。涵盖项目结构、技术栈选择及关键依赖项的配置。 ... [详细]
  • Mongoose 5.12.10 发布:MongoDB 异步对象模型工具的新特性与修复
    Mongoose 是一款专为异步环境设计的 MongoDB 对象模型工具,支持 Promise 和回调函数。最新版本 Mongoose 5.12.10 带来了多项修复和改进,包括查询选项中的默认值设置、嵌入式判别器填充、以及 TypeScript 定义文件的优化。 ... [详细]
  • 58同城的Elasticsearch应用与平台构建实践
    本文由58同城高级架构师于伯伟分享,由陈树昌编辑整理,内容源自DataFunTalk。文章探讨了Elasticsearch作为分布式搜索和分析引擎的应用,特别是在58同城的实施案例,包括集群优化、典型应用实例及自动化平台建设等方面。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 本文详细介绍了网络存储技术的基本概念、分类及应用场景。通过分析直连式存储(DAS)、网络附加存储(NAS)和存储区域网络(SAN)的特点,帮助读者理解不同存储方式的优势与局限性。 ... [详细]
  • 本文探讨了大数据生态系统的构建,重点介绍其分布式存储和运算机制,并补充相关技术及应用场景。 ... [详细]
author-avatar
手机用户2502913993
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有