Linux CentOS运维中,常用的操作和命令记录下:

1、DNS设置

  在Linux服务器上,当我们ping出现这个错误时:ping: unknown host,很大可能是系统的DNS没有设置或者设置错误。在 /etc/resolv.conf 中,设置下即可:

# cat /etc/resolv.conf
nameserver 8.8.8.8
nameserver 8.8.4.4

2、FTP客户端配置

  当我们需要在Linux服务器上连某个FTP,输入ftp命名提示这个错误时:-bash: ftp: command not found,可能是服务器上没有安装FTP客户端。我们可以到http://mirror.centos.org/centos/5/os/i386/CentOS/ 下,找到ftp的rpm package的安装包地址下载后执行安装:

# rpm -Uvh http://mirror.centos.org/centos/5/os/i386/CentOS/ftp-0.17-38.el5.i386.rpm

3、防火墙配置

  Linux的防火墙相信大家都不会陌生,iptables 功能很强大,我们暂时只列出我们常用的,比如当前系统只开放了SSH的22端口,

[root@localhost /]# cat /etc/sysconfig/iptables
# Firewall configuration written by system-config-firewall
# Manual customization of this file is not recommended.
*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
-A INPUT -i lo -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT
-A INPUT -j REJECT --reject-with icmp-host-prohibited
-A FORWARD -j REJECT --reject-with icmp-host-prohibited

我们再加一行,

-A INPUT -m state --state NEW -m tcp -p tcp --dport 8080 -j ACCEPT,放开对8080端口的访问;

-A INPUT -s 192.168.4.6 -p tcp --dport 22 -j ACCEPT,只允许192.168.4.6的机器进行SSH连接;

如果要允许或限制一段IP地址可用 192.168.0.0/24 表示192.168.0.1-255端的所有IP地址。

修改完后,需要重启下iptables,配置才能生效:

[root@localhost /]# service iptables restart

4、nginx部署

  先到官网下载.tar.gz的安装包:http://nginx.org/en/download.html,然后解压到你想要的目录:

tar zxvf nginx-1.8.0.tar.gz

设置配置信息、编译、安装:

./configure --prefix=/home/nginx/nginx/nginx-1.8.0
make
make install

如果编辑和安装的过程中,没有出现 error 之类的错误描述,并且 nginx的根目录生成了sbin文件夹,那么恭喜你,安装成功了!

不过我的服务器环境在 make 编辑的时候,出错了:./configure: error: the HTTP rewrite module requires the PCRE library 。

错误提示是缺少PCRE库,因为nginx的rewrite依赖于PCRE库,所以需要在linux中编译安装下PCRE库。。。

我们可以到 http://sourceforge.net/projects/pcre/files/pcre/ 下,选择下载一个PCRE的版本,解压后,老规矩,配置编译安装:

tar zxvf pcre-8.36.tar.gz
./configure
make
make install

安装成功后,我们再接着编译安装下 nginx。嗯,这下没error提示,安装成功了。启动nginx:

cd /home/nginx/nginx-1.8.0/sbin
./nginx

但是又出错了:./nginx: error while loading shared libraries: libpcre.so.1: cannot open shared object file: No such file or directory

网上查了下,据说是因为没有给动态链接库创建链接,执行如下命令即可:

ln -s /usr/local/lib/libpcre.so.1 /lib     #32位系统
ln -s /usr/local/lib/libpcre.so.1 /lib64 #64位系统

最后,再 ./nginx 启动。

可以通过 ps -ef | grep nginx 查看,如果有2个nginx进程(一个master 一个worker),那么 nginx 已经正常启动了,打开本机的浏览器,访问 http://服务器ip,亲切的画面迎面而来!

发现也可以用yum的方法来安装:

rpm -ivh http://nginx.org/packages/centos/6/noarch/RPMS/nginx-release-centos-6-0.el6.ngx.noarch.rpm

查看下yum的nginx信息:

yum info nginx

然后安装:

yum install nginx

最后启动nginx:

service nginx start

5、Tomcat部署

  先到官网下载.tar.gz的安装包: http://tomcat.apache.org/download-70.cgi,或者wget直接下载到服务器:

wget http://apache.fayea.com/tomcat/tomcat-7/v7.0.64/bin/apache-tomcat-7.0.64.tar.gz

然后解压到你想要的目录:

tar zxvf apache-tomcat-6.0.44.tar.gz

环境变量我没配,

到tomcat的bin目录启动tomcat:

./catalina.sh start 

到tomcat的bin目录关闭tomcat:

./shutdown.sh stop

查看tomcat是否安装成功:

netstat -tnlp|grep java

6、date命令

# date -R
Wed, 19 Aug 2015 14:00:40 +0800
# date +%F
2015-08-19
# date +'%F %T'
2015-08-19 14:00:58

7、强大的Find和grep

当我们要删除某类文件,比如2天之前的日志文件时:

find /home/policy/log -mtime +2 -name "*.log" -exec rm -rf {} \;

-mtime:标准写法

+2:查找2天前的文件,这里用数字表示天数

"*.*":希望查找的文件类型,"*.log"表示查找扩展后缀名为log的所有文件,"*"表示查找所有文件

-exec:固定写法

rm -rf:强制删除文件,包括目录 (rm -rf 非常危险,执行之前一定要再三确认哟~)

{} \; :固定写法,一对大括号+空格+ \

比如查找某个文件夹

find / -name nginx

模糊查询

find / -name "*tomcat*"

模糊查找指定文件里面的内容

 grep -n '192.168' config.properties

查找指定文件中某天的日志,并且含有android关键字(不区分大小写)的日志数量

grep "10/Nov/2017" host.access.log|grep -i "android" | wc -l

查询指定文件中含有 ipad或iphone关键字(不区分大小写)并且对关键字精确匹配的日志

grep -iwE "ipad;|iphone;" host.access.log 

查询某类文件中含有error关键字的日志内容

find -type f -name '*.log'|xargs grep 'error'

8、端口占用情况

 查看linux端口的使用情况:netstat -tlnp  

              netstat -nat

  查看某个进程的端口使用情况,比如tomcat,先查看tomcat的进程号:ps -ef | grep tomcat*

  (后面带*,是为了查看多个tomcat如tomcat6,tomcat7等)

  再根据进程号查看端口号,比如上面查出来tomcat的进程id是5811:netstat -anop | grep 5811

  检测端口是否启用:ss -tnl

9、实时监控网卡流量

单网卡:watch -n 1 "ifconfig eth0"

所有网卡:watch cat /proc/net/dev

     watch more /proc/net/dev

10、服务器配置查看

系统版本:cat /etc/redhat-release、lsb_release  -a

操作系统位数:getconf LONG_BIT

物理CPU个数:cat /proc/cpuinfo | grep "physical id" | sort | uniq | wc -l

每个物理CPU中core的个数(核数):cat /proc/cpuinfo| grep "cpu cores"| uniq

11、iconv批量转换windows文件成linux文件

windwos文件中的文件上传到linux后由于编码不同,可能会导致乱码。

先查看文件编码:

file filename

再递归转换(含子文件夹):

find test -type d -exec mkdir -p /home/maoniu/{} \;
find test -type f -exec iconv -f GBK -t UTF-8 {} -o /home/maoniu/{} \;

(将test目录下的文件由GBK编码转换为UTF-8编码,目录结构不变,转码后的文件保存在/home/maoniu/test目录下)

注意:如果原来就是utf-8编码,使用iconv -f GBK -t UTF-8命令转换后,会出现乱码,或截断等各种问题;一定要保证原文件是不是utf-8编码;

使用如下命令把文件编码先查出来:find test-type f -exec file -i {} \; > /tmp/test

查询是否存在已经是utf-8编码的文件:grep "charset=utf-8" /tmp/test

12、使用nc做TCP和UDP端口扫描

TCP扫描

nc -nvz 192.168.1.105 1-65535 进行扫描,

-z : 探测到端口后就退出,不进行连接。

UDP扫描

nc -nvzu 192.168.1.105 1-1024 进行扫描,

-u : UDP

13、windows与linux通过sftp上传下载

按下ALT+P 开启新的会话,进行sftp操作。可输入: help命令,显示所有支持的命令

pwd:  查询linux主机所在目录(也就是远程主机目录)
         lpwd:  查询本地目录(指windows上传文件的目录:我们可以通过查看"选项"下拉框中的"会话选项")
               ls:  查询连接到当前linux主机所在目录有哪些文件
              lls:  查询当前本地上传目录有哪些文件
             lcd:  改变本地上传目录的路径
              cd:   改变远程上传目录
             get:  将远程目录中文件下载到本地目录
             put:  将本地目录中文件上传到远程主机(linux)
            quit:  断开FTP连接

14、CP

例 复制源目录 为 dir1 ,目标目录为dir2

如果dir2目录不存在:cp -r dir1 dir2

如果dir2目录已存在:cp -r dir1/. dir2

若不想看到提示直接覆盖使用 -rf 。如果还是提示是否覆盖,可以在CP命令前面加一个斜杠\ ,即: \cp -rf dir1/. dir2

14、查看进程启动和执行时间

ps -eo pid,lstart,etime,cmd | grep redis

Linux简单指令操作的更多相关文章

  1. VMware与CentOS的安装与Linux简单指令

    一 . VMware与CentOS系统安装 下载CentOS系统的ISO镜像 # 官方网站,国外网站,下载速度会很慢 www.centos.org # 由于国外的下载速度慢,我们可以使用国内的镜像源 ...

  2. linux常见的操作指令

    一:非正确退出程序,再次启动显示端口被占用 netstat -ntulp n ---  显示ip代替网络接口信息,显示出网络连接情况 t  ---  显示TCP协议的链接状况 u ---  显示UDP ...

  3. Linux基础指令

    Linux基础指令 只写了最简单的一些文件操作,基本没有带参数 查看当前目录 pwd 跳转到某路径 cd 查看当前目录下的文件 ls ls -l // -l 查看详细信息 打开当前所在文件夹 open ...

  4. linux下时间操作1

    本文是对我之前写的文章:C++时间操作 的更深入补充.之前那个文章就是一个快速入门的东西,后面力图把一些更深入的细节补充完整. 时间分类的基本介绍 在介绍一些时间相关的操作函数之前,先来介绍一下lin ...

  5. Linux常用指令(三)

    进入京东运维组实习,收到了很多同事的热心指导,自己也努力学习,按照他们给出的学习计划,真的很充实,学到了很多不只是开发方面的知识. 以下简单记录下自己的笔记,方便以后查阅. 1.文件系统 Linux系 ...

  6. 一篇文章带你了解服务器操作系统——Linux简单入门

    一篇文章带你了解服务器操作系统--Linux简单入门 Linux作为服务器的常用操作系统,身为工作人员自然是要有所了解的 在本篇中我们会简单介绍Linux的特点,安装,相关指令使用以及内部程序的安装等 ...

  7. linux终端指令总结

    一直没机会进行linux指令的系统学习,但是工作中总能遇到通过指令操作文件或数据库的情况,总不能一味地依赖后端开发者的帮忙.上任领导说过,要是在同一个地方跌倒,那么你就是傻子.我可不想成为傻子,so, ...

  8. linux常用指令

    整理下来的linux常用指令 mount [-t 文件系统] 设备文件名 挂载点挂载命令,一般用于在挂载ISO,或者其他比如U盘等设备时使用,[-t iso9660]为固定格式,可写可不写,非必写项. ...

  9. Linux压缩指令

    1.windows系统和Linux系统的压缩文件只有zip格式的是通用的 2.windows系统可以解压几乎所有的Linux压缩格式 3.Linux压缩指令 gzip 指令 格式: gzip 压缩的文 ...

随机推荐

  1. Fis3的前端工程化之路[三大特性篇之声明依赖]

    Fis3版本:v3.4.22 Fis3的三大特性 资源定位:获取任何开发中所使用资源的线上路径 内容嵌入:把一个文件的内容(文本)或者base64编码(图片)嵌入到另一个文件中 依赖声明:在一个文本文 ...

  2. mysql 学习总结

    MYSQL的增.删.查.改   注册.授权 #创建一个对数据库中的表有一些操作权限的用户,其中OPERATION可以用all privileges替换,DBNAME.TABLENAME可以用*替换,表 ...

  3. 自己实现一个javascript事件模块

    nodejs中的事件模块 nodejs中有一个events模块,用来给别的函数对象提供绑定事件.触发事件的能力.这个别的函数的对象,我把它叫做事件宿主对象(非权威叫法),其原理是把宿主函数的原型链指向 ...

  4. Node.js:dgram模块实现UDP通信

    1.什么是UDP? 这里简单介绍下,UDP,即用户数据报协议,一种面向无连接的传输层协议,提供不可靠的消息传送服务.UDP协议使用端口号为不同的应用保留其各自的数据传输通道,这一点非常重要.与TCP相 ...

  5. CSS 3 学习——渐变

    通过CSS渐变创建的是一个没有固定比例和固定尺寸的<image>类型,也就是说是一张图片,这张图片的尺寸由所应用的元素的相关信息决定.凡是支持图片类型的CSS属性都可以设置渐变,而支持颜色 ...

  6. GJM : C#设计模式汇总整理——导航 【原创】

    感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...

  7. 中国CIO最关心的八大问题(上)

    中国CIO最关心的八大问题(上) 近期,ITValue和ValueResearch联合展开<IT决策者投资与生存状态大调查>,调查范围从关注CIO本身,延展至关注CIO所供职企业--其赖以 ...

  8. 分享两个BPM配置小技巧

    1.小技巧 流程图修改后发布的话版本号会+1,修改次数多了之后可能会导致版本号很高,这个时候可以将流程导出,然后删除对应的流程包再导入,发布数据模型和流程图之后,版本清零 2.小技巧 有的同事入职后使 ...

  9. Jquery 获得当前标签的名称和标签属性

    得到标签的名称 $("#name").prop("tagName"); 或者 $("#name")[0].tagName; 注意:1.得到的 ...

  10. ABP源码分析二:ABP中配置的注册和初始化

    一般来说,ASP.NET Web应用程序的第一个执行的方法是Global.asax下定义的Start方法.执行这个方法前HttpApplication 实例必须存在,也就是说其构造函数的执行必然是完成 ...