linux中shell常用操作命令系列:服务操作
下文给大家整理一些linux中shell常用操作命令系列:服务操作例子,希望能帮助到大家.
基本操作:
- /etc/init.d/sendmailstart#启动服务
- /etc/init.d/sendmailstop#关闭服务
- /etc/init.d/sendmailstatus#查看服务当前状态
- /date/mysql/bin/mysqld_safe--user=mysql&#启动mysql后台运行
- vi/etc/rc.d/rc.local#开机启动执行可用于开机启动脚本
- /etc/rc.d/rc3.d/S55sshd#开机启动和关机关闭服务连接#S开机startK关机stop55级别后跟服务名
- ln-s-f/date/httpd/bin/apachectl/etc/rc.d/rc3.d/S15httpd#将启动程序脚本连接到开机启动目录
- ipvsadm-ln#lvs查看后端负载机并发
- ipvsadm-C#lvs清除规则
- xmlist#查看xen虚拟主机列表
- virsh#虚拟化(xenkvm)管理工具yumgroupinstallVirtual*
- ./bin/httpd-M#查看httpd加载模块
- httpd-t-DDUMP_MODULES#rpm包httpd查看加载模块
- echo内容|/bin/mail-s"标题"收件箱-f发件人#发送邮件
- "`echo"内容"|iconv-futf8-tgbk`"|/bin/mail-s"`echo"标题"|iconv-futf8-tgbk`"收件箱#解决邮件乱码
- /usr/local/nagios/bin/nagios-v/usr/local/nagios/etc/nagios.cfg#检测nagios配置文件
- chkconfig常用操作
- chkconfig服务名on|off|set#设置非独立服务启状态
- chkconfig--level35httpdoff#让服务不自动启动
- chkconfig--level35httpdon#让服务自动启动35指的是运行级别
- chkconfig--list#查看所有服务的启动状态
- chkconfig--list|grephttpd#查看某个服务的启动状态
- chkconfig–-list[服务名称]#查看服务的状态httpd基本操作
编译参数:
- #so模块用来提供DSO支持的apache核心模块
- #如果编译中包含任何DSO模块,则mod_so会被自动包含进核心。
- #如果希望核心能够装载DSO,但不实际编译任何DSO模块,则需明确指定"--enable-so=static"
- ./configure--prefix=/usr/local/apache--enable-so--enable-mods-shared=most--enable-rewrite--enable-forward#实例编译
- --with-mpm=worker#已worker方式运行
- --with-apxs=/usr/local/apache/bin/apxs#制作apache的动态模块DSOrpm包httpd-devel#编译模块apxs-i-a-cmod_foo.c
- --enable-so#让Apache可以支持DSO模式
- --enable-mods-shared=most#告诉编译器将所有标准模块都动态编译为DSO模块
- --enable-rewrite#支持地址重写功能
- --enable-module=most#用most可以将一些不常用的,不在缺省常用模块中的模块编译进来
- --enable-mods-shared=all#意思是动态加载所有模块,如果去掉-shared话,是静态加载所有模块
- --enable-expires#可以添加文件过期的限制,有效减轻服务器压力,缓存在用户端,有效期内不会再次访问服务器,除非按f5刷新,但也导致文件更新不及时
- --enable-deflate#压缩功能,网页可以达到40%的压缩,节省带宽成本,但会对cpu压力有一点提高
- --enable-headers#文件头信息改写,压缩功能需要
- --disable-MODULE#禁用MODULE模块(仅用于基本模块)
- --enable-MODULE=shared#将MODULE编译为DSO(可用于所有模块)
- --enable-mods-shared=MODULE-LIST#将MODULE-LIST中的所有模块都编译成DSO(可用于所有模块)
- --enable-modules=MODULE-LIST#将MODULE-LIST静态连接进核心(可用于所有模块)
- #上述MODULE-LIST可以是:
- 1、用引号界定并且用空格分隔的模块名列表--enable-mods-shared='headersrewritedav'
- 2、"most"(大多数模块)--enable-mods-shared=most
- 3、"all"(所有模块)
http转发配置:
- #针对非80端口的请求处理
- RewriteCond%{SERVER_PORT}!^80$
- RewriteRule^/(.*)http://fully.qualified.domain.name:%{SERVER_PORT}/$1[L,R]
- RewriteCond%{HTTP_HOST}^ss.aa.com[NC]
- RewriteRule^(.*)http://www.aa.com/so/$1/0/p0?[L,R=301]
- #RewriteRule只对?前处理,所以会把?后的都保留下来
- #在转发后地址后加?即可取消RewriteRule保留的字符
- #R的含义是redirect,即重定向,该请求不会再被apache交给后端处理,而是直接返回给浏览器进行重定向跳转。301是返回的http状态码,具体可以参考httprfc文档,跳转都是3XX。
- #L是last,即最后一个rewrite规则,如果请求被此规则命中,将不会继续再向下匹配其他规则。
MySQL常用操作,MySQL源码安装:
- groupaddmysql
- useraddmysql-gmysql-M-s/bin/false
- tarzxvfmysql-5.1.71.tar.gz
- cdmysql-5.1.71
- ./configure--prefix=/usr/local/mysql
- --with-client-ldflags=-all-static
- --with-mysqld-ldflags=-all-static
- --with-mysqld-user=mysql
- --with-extra-charsets=all
- --with-unix-socket-path=/var/tmp/mysql.sock
- make&&makeinstall
- #生成mysql用户数据库和表文件,在安装包中输入
- scripts/mysql_install_db--user=mysql
- vi~/.bashrc
- exportPATH="$PATH:/usr/local/mysql/bin"
- #配置文件,有large,medium,small三个,根据机器性能选择
- cpsupport-files/my-medium.cnf/etc/my.cnf
- cpsupport-files/mysql.server/etc/init.d/mysqld
- chmod700/etc/init.d/mysqld
- cd/usr/local
- chmod750mysql-R
- chgrpmysqlmysql-R
- chownmysqlmysql/var-R
- cp/usr/local/mysql/libexec/mysqldmysqld.old
- ln-s/usr/local/mysql/bin/mysql/sbin/mysql
- ln-s/usr/local/mysql/bin/mysqladmin/sbin/mysqladmin
- ln-s-f/usr/local/mysql/bin/mysqld_safe/etc/rc.d/rc3.d/S15mysql5//phpfensi.com
- ln-s-f/usr/local/mysql/bin/mysqld_safe/etc/rc.d/rc0.d/K15mysql5
mysql常用命令:
- ./mysql/bin/mysqld_safe--user=mysql&#启动mysql服务
- ./mysql/bin/mysqladmin-uroot-p-S./mysql/data/mysql.sockshutdown#停止mysql服务
- mysqlcheck-uroot-p-Smysql.sock--optimize--databasesaccount#检查、修复、优化MyISAM表
- mysqlbinlogslave-relay-bin.000001#查看二进制日志(报错加绝对路径)
- mysqladmin-hmyhost-uroot-pcreatedbname#创建数据库
- flushprivileges;#刷新
- showdatabases;#显示所有数据库
- usedbname;#打开数据库
- showtables;#显示选中数据库中所有的表
- desctables;#查看表结构
- dropdatabasename;#删除数据库
- droptablename;#删除表
- createdatabasename;#创建数据库
- select列名称from表名称;#查询
- showgrantsforrepl;#查看用户权限
- showprocesslist;#查看mysql进程
- selectuser();#查看所有用户
- showslavestatusG;#查看主从状态
- showvariables;#查看所有参数变量
- showtablestatus#查看表的引擎状态
- droptableifexistsuser#表存在就删除
- createtableifnotexistsuser#表不存在就创建
- selecthost,user,passwordfromuser;#查询用户权限先usemysql
- createtableka(ka_idvarchar(6),qianshuint);#创建表
- SHOWVARIABLESLIKE'character_set_%';#查看系统的字符集和排序方式的设定
- showvariableslike'%timeout%';#查看超时(wait_timeout)
- deletefromuserwhereuser='';#删除空用户
- deletefromuserwhereuser='sss'andhost='localhost';#删除用户
- ALTERTABLEmytableENGINE=MyISAM;#改变现有的表使用的存储引擎
- SHOWTABLESTATUSfrom库名whereName='表名';#查询表引擎
- CREATETABLEinnodb(idint,titlechar(20))ENGINE=INNODB#创建表指定存储引擎的类型(MyISAM或INNODB)
- grantreplicationslaveon*.*to'用户'@'%'identifiedby'密码';#创建主从复制用户
- ALTERTABLEplayerADDINDEXweekcredit_faction_index(weekcredit,faction);#添加索引
- altertablenameaddcolumnaccountid(列名)int(11)NOTNULL(字段不为空);#插入字段
- updatehostsetmonitor_state='Y',hostname='xuesong'whereip='192.168.1.1';#更新数据
- 创建MySQL自增表
- createtableoldBoy(idINTEGERPRIMARYKEYAUTO_INCREMENT,nameCHAR(30)NOTNULL,ageinteger,sexCHAR(15));#创建自增表
- insertintooldBoy(name,age,sex)values(%s,%s,%s)#自增插入数据
- 登录mysql的命令
- #格式:mysql-h主机地址-u用户名-p用户密码
- mysql-h110.110.110.110-P3306-uroot-p
- mysql-uroot-p-S/data1/mysql5/data/mysql.sock-A--default-character-set=GBK
- shell执行mysql命令
- mysql-uroot-p'123'test<file.sql#针对指定库执行sql文件中的语句,好处不需要转义特殊符号,一条语句可以换行.不指定库执行时语句中需要先use
- mysql-u$username-p$passwd-h$dbhost-P$dbport-A-e"
- use$dbname;
- deletefromdatawheredate=('$date1');
- "#执行多条mysql命令
- mysql-uroot-p-Smysql.sock-e"usedb;altertablegiftaddcolumnaccountidint(11)NOTNULL;flushprivileges;"#不登陆mysql插入字段
- 备份MySQL数据库
- mysqldump-hhost-uroot-p--default-character-set=utf8dbname>dbname_backup.sql#不包括库名,还原需先创建库,在use
- mysqldump-hhost-uroot-p--database--default-character-set=utf8dbname>dbname_backup.sql#包括库名,还原不需要创建库
- /bin/mysqlhotcopy-uroot-p#mysqlhotcopy只能备份MyISAM引擎
- mysqldump-uroot-p-Smysql.sock--default-character-set=utf8dbnametable1table2>/data/db.sql#备份表
- mysqldump-uroot-p123-ddatabase>database.sql#备份数据库结构
- innobackupex--user=root--password=""--defaults-file=/data/mysql5/data/my_3306.cnf--socket=/data/mysql5/data/mysql.sock--slave-info--stream=tar--tmpdir=/data/dbbackup/temp/data/dbbackup/2>/data/dbbackup/dbbackup.log|gzip1>/data/dbbackup/db50.tar.gz#xtrabackup备份需单独安装软件优点:速度快,压力小,可直接恢复主从复制
- 还原MySQL数据库
- mysql-hhost-uroot-pdbname<dbname_backup.sql
- source路径.sql#登陆mysql后还原sql文件
- 为MySQL赋权限
- #指定IP:$IP本机:localhost所有IP地址:%#通常指定多条
- grantallonzabbix.*touser@"$IP";#对现有账号赋予权限
- grantselectondatabase.*touser@"%"Identifiedby"passwd";#赋予查询权限(没有用户,直接创建)
- grantallprivilegesondatabase.*touser@"$IP"identifiedby'passwd';#赋予指定IP指定用户所有权限(不允许对当前库给其他用户赋权限)
- grantallprivilegesondatabase.*touser@"localhost"identifiedby'passwd'withgrantoption;#赋予本机指定用户所有权限(允许对当前库给其他用户赋权限)
- grantselect,insert,update,deleteondatabase.*touser@'ip'identifiedby"passwd";#开放管理操作指令
- revokeallon*.*fromuser@localhost;#回收权限
- MySQL用户更改密码
- updateusersetpassword=password('passwd')whereuser='root'
- mysqladmin-urootpassword'xuesong'
MySQL忘记密码后重置:
- cd/data/mysql5
- /data/mysql5/bin/mysqld_safe--user=mysql--skip-grant-tables--skip-networking&
- usemysql;
- updateusersetpassword=password('123123')whereuser='root';
MySQL主从复制失败恢复:
- slavestop;
- resetslave;
- changemastertomaster_host='10.10.10.110',master_port=3306,master_user='repl',master_password='repl',master_log_file='master-bin.000010',master_log_pos=107,master_connect_retry=60;
- slavestart;
SQL语句使用变量:
- usexuesong;
- set@a=concat('my',weekday(curdate()));#组合时间变量
- set@sql:=concat('CREATETABLEIFNOTEXISTS',@a,'(idINT(11)NOTNULL)');#组合sql语句
- select@sql;#查看语句
- preparecreate_tbfrom@sql;#准备
- executecreate_tb;#执行
检测MySQL主从复制延迟:
1、在从库定时执行更新主库中的一个timeout数值
2、同时取出从库中的timeout值对比判断从库与主库的延迟
MySQL慢查询:
开启慢查询日志
log-slow-queries=/var/lib/mysql/slowquery.log # 指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log
long_query_time=2 # 记录超过的时间,默认为10s
log-queries-not-using-indexes # log下来没有使用索引的query,可以根据情况决定是否开启,可不加.
log-long-format # 如果设置了,所有没有使用索引的查询也将被记录,可不加.
mysqldumpslow慢查询日志查看
-s # 是order的顺序,包括看了代码,主要有 c,t,l,r和ac,at,al,ar,分别是按照query次数,时间,lock的时间和返回的记录数来排序,前面加了a的时倒序.
-t # 是top n的意思,即为返回前面多少条的数据
-g # 后边可以写一个正则匹配模式,大小写不敏感的
mysqldumpslow -s c -t 20 host-slow.log # 访问次数最多的20个sql语句
mysqldumpslow -s r -t 20 host-slow.log # 返回记录集最多的20个sql
mysqldumpslow -t 10 -s t -g "left join" host-slow.log # 按照时间返回前10条里面含有左连接的sql语句
show global status like '%slow%'; # 查看现在这个session有多少个慢查询
show variables like '%slow%'; # 查看慢查询日志是否开启,如果slow_query_log和log_slow_queries显示为on,说明服务器的慢查询日志已经开启
show variables like '%long%'; # 查看超时阀值
desc select * from wei where text='xishizhaohua'G; # 扫描整张表 tepe:ALL 没有使用索引 key:NULL
create index text_index on wei(text); # 创建索引
mongodb常用操作:
一、启动:
- #不启动认证
- ./mongod--port27017--fork--logpath=/opt/mongodb/mongodb.log--logappend--dbpath=/opt/mongodb/data/
- #启动认证
- ./mongod--port27017--fork--logpath=/opt/mongodb/mongodb.log--logappend--dbpath=/opt/mongodb/data/--auth
- #配置文件方式启动
- cat/opt/mongodb/mongodb.conf
- port=27017#端口号
- fork=true#以守护进程的方式运行,创建服务器进程
- auth=true#开启用户认证
- logappend=true#日志采用追加方式
- logpath=/opt/mongodb/mongodb.log#日志输出文件路径
- dbpath=/opt/mongodb/data/#数据库路径
- shardsvr=true#设置是否分片
- maxConns=600#数据库的最大连接数
- ./mongod-f/opt/mongodb/mongodb.conf
- #其他参数
- bind_ip#绑定IP使用mongo登录需要指定对应IP
- journal#开启日志功能,降低单机故障的恢复时间,取代dur参数
- syncdelay#系统同步刷新磁盘的时间,默认60秒
- directoryperdb#每个db单独存放目录,建议设置.与mysql独立表空间类似
- repairpath#执行repair时的临时目录.如果没开启journal,出现异常重启,必须执行repair操作
- #mongodb没有参数设置内存大小.使用osmmap机制缓存数据文件,在数据量不超过内存的情况下,效率非常高.数据量超过系统可用内存会影响写入性能
二、关闭
- #方法一:登录mongodb
- ./mongo
- useadmin
- db.shutdownServer()
- #方法:kill传递信号两种皆可
- kill-2pid
- kill-15pid
三、开启认证与用户管理
- ./mongo#先登录
- useadmin#切换到admin库
- db.addUser("root","123456")#创建用户
- db.addUser('zhansan','pass',true)#如果用户的readOnly为true那么这个用户只能读取数据,添加一个readOnly用户zhansan
- ./mongo127.0.0.1:27017/mydb-uroot-p123456#再次登录,只能针对用户所在库登录
- #虽然是超级管理员,但是admin不能直接登录其他数据库,否则报错
- #FriNov2215:03:21.886Error:18{code:18,ok:0.0,errmsg:"authfails"}atsrc/mongo/shell/db.js:228
- showcollections#查看链接状态再次登录使用如下命令,显示错误未经授权
- db.system.users.find();#查看创建用户信息
- db.system.users.remove({user:"zhansan"})#删除用户
- #恢复密码只需要重启mongodb不加--auth参数
四、登录:
- 192.168.1.5:28017 #http登录后可查看状态
- ./mongo #默认登录后打开test库
- ./mongo192.168.1.5:27017/databaseName#直接连接某个库不存在则创建启动认证需要指定对应库才可登录
五、查看状态:
- #登录后执行命令查看状态
- db.runCommand({"serverStatus":1})
- globalLock#表示全局写入锁占用了服务器多少时间(微秒)
- mem#包含服务器内存映射了多少数据,服务器进程的虚拟内存和常驻内存的占用情况(MB)
- indexCounters#表示B树在磁盘检索(misses)和内存检索(hits)的次数.如果这两个比值开始上升,就要考虑添加内存了
- backgroudFlushing#表示后台做了多少次fsync以及用了多少时间
- opcounters#包含每种主要擦撞的次数
- asserts#统计了断言的次数
- #状态信息从服务器启动开始计算,如果过大就会复位,发送复位,所有计数都会复位,asserts中的roolovers值增加
- #mongodb自带的命令
- ./mongostat
- insert#每秒插入量
- query#每秒查询量
- update#每秒更新量
- delete#每秒删除量
- locked#锁定量
- qr|qw#客户端查询排队长度(读|写)
- ar|aw#活跃客户端量(读|写)
- conn#连接数
- time#当前时间
六、常用命令
- db.listCommands()#当前MongoDB支持的所有命令(同样可通过运行命令db.runCommand({"listCommands":`1})来查询所有命令)
- db.runCommand({"buildInfo":1})#返回MongoDB服务器的版本号和服务器OS的相关信息。
- db.runCommand({"collStats":集合名})#返回该集合的统计信息,包括数据大小,已分配存储空间大小,索引的大小等。
- db.runCommand({"distinct":集合名,"key":键,"query":查询文档})#返回特定文档所有符合查询文档指定条件的文档的指定键的所有不同的值。
- db.runCommand({"dropDatabase":1})#清空当前数据库的信息,包括删除所有的集合和索引。
- db.runCommand({"isMaster":1})#检查本服务器是主服务器还是从服务器。
- db.runCommand({"ping":1})#检查服务器链接是否正常。即便服务器上锁,该命令也会立即返回。
- db.runCommand({"repaireDatabase":1})#对当前数据库进行修复并压缩,如果数据库特别大,这个命令会非常耗时。
- db.runCommand({"serverStatus":1})#查看这台服务器的管理统计信息。
- #某些命令必须在admin数据库下运行,如下两个命令:
- db.runCommand({"renameCollection":集合名,"to":集合名})#对集合重命名,注意两个集合名都要是完整的集合命名空间,如foo.bar,表示数据库foo下的集合bar。
- db.runCommand({"listDatabases":1})#列出服务器上所有的数据库
七、进程控制
- db.currentOp()#查看活动进程
- db.$cmd.sys.inprog.findOne()#查看活动进程与上面一样
- opid#操作进程号
- op#操作类型(查询更新)
- ns#命名空间,指操作的是哪个对象
- query#如果操作类型是查询,这里将显示具体的查询内容
- lockType#锁的类型,指明是读锁还是写锁
- db.killOp(opid值)#结束进程
- db.$cmd.sys.killop.findOne({op:opid值})#结束进程
八、备份还原
- ./mongoexport-dtest-ct1-ot1.dat#导出JSON格式
- -c#指明导出集合
- -d#使用库
- ./mongoexport-dtest-ct1-csv-fnum-ot1.dat#导出csv格式
- -csv#指明导出csv格式
- -f#指明需要导出那些例
- db.t1.drop()#登录后删除数据
- ./mongoimport-dtest-ct1-filet1.dat#mongoimport还原JSON格式
- ./mongoimport-dtest-ct1-typecsv--headerline-filet1.dat#mongoimport还原csv格式数据
- --headerline#指明不导入第一行因为第一行是列名
- ./mongodump-dtest-o/bak/mongodump#mongodump数据备份
- ./mongorestore-dtest--drop/bak/mongodump/*#mongorestore恢复
- --drop#恢复前先删除
- db.t1.find()#查看
- #mongodump虽然能不停机备份,但市区了获取实时数据视图的能力,使用fsync命令能在运行时复制数据目录并且不会损坏数据
- #fsync会强制服务器将所有缓冲区的数据写入磁盘.配合lock还阻止对数据库的进一步写入,知道释放锁为止
- #备份在从库上备份,不耽误读写还能保证实时快照备份
- db.runCommand({"fsync":1,"lock":1})#执行强制更新与写入锁
- db.$cmd.sys.unlock.findOne()#解锁
- db.currentOp()#查看解锁是否正常
九、修复
- #当停电或其他故障引起不正常关闭时,会造成部分数据损坏丢失
- ./mongod--repair#修复操作:启动时候加上--repair
- #修复过程:将所有文档导出,然后马上导入,忽略无效文档.完成后重建索引。时间较长,会丢弃损坏文档
- #修复数据还能起到压缩数据库的作用
- db.repairDatabase()#运行中的mongodb可使用repairDatabase修复当前使用的数据库
- {"repairDatabase":1}#通过驱动程序
十、python使用mongodb
- easy_installpymongo#安装(python2.7+)
- importpymongo
- connection=pymongo.Connection('localhost',27017)#创建连接
- db=connection.test_database#切换数据库
- collection=db.test_collection#获取collection
- #db和collection都是延时创建的,在添加Document时才真正创建
- 文档添加,_id自动创建
- importdatetime
- post={"author":"Mike",
- "text":"Myfirstblogpost!",
- "tags":["mongodb","python","pymongo"],
- "date":datetime.datetime.utcnow()}
- posts=db.posts
- posts.insert(post)
- ObjectId('...')
- 批量插入
- new_posts=[{"author":"Mike",
- "text":"Anotherpost!",
- "tags":["bulk","insert"],
- "date":datetime.datetime(2009,11,12,11,14)},
- {"author":"Eliot",
- "title":"MongoDBisfun",
- "text":"andprettyeasytoo!",
- "date":datetime.datetime(2009,11,10,10,45)}]
- posts.insert(new_posts)
- [ObjectId('...'),ObjectId('...')]
- 获取所有collection
- db.collection_names()#相当于SQL的showtables
- 获取单个文档
- posts.find_one()
- 查询多个文档
- forpostinposts.find():
- post
- 加条件的查询
- posts.find_one({"author":"Mike"})
- 高级查询
- posts.find({"date":{"$lt":"d"}}).sort("author")
- 统计数量
- posts.count()
- 加索引
- frompymongoimportASCENDING,DESCENDING
- posts.create_index([("date",DESCENDING),("author",ASCENDING)])
- 查看查询语句的性能
- posts.find({"date":{"$lt":"d"}}).sort("author").explain()["cursor"]
- posts.find({"date":{"$lt":"d"}}).sort("author").explain()["nscanned"]
- JDK安装
- chmod744jdk-6u24-linux-x64.bin
- ./jdk-6u24-linux-x64.bin
- vi/etc/profile#添加环境变量
- exportJAVA_HOME=/usr/java/jdk1.6.0_24
- exportCLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
- exportPATH=$PATH:$JAVA_HOME/bin
- ./etc/profile
- jps-ml#查看java进程
热门评论