一、基本命令
1.1 关机和重启
关机
1 | shutdown -h now 立刻关机 |
重启
1 | shutdown -r now 立刻重启 |
1.2 帮助命令
–help命令
1 | shutdown --help: |
man命令(命令说明书)
1 | man shutdown |
二、目录操作命令
2.1 目录切换 cd
命令:cd 目录
1 | cd / 切换到根目录 |
2.2 目录查看 ls [-al]
命令:ls [-al]
1 | ls 查看当前目录下的所有目录和文件 |
2.3 目录操作【增,删,改,查】
2.3.1 创建目录【增】 mkdir
命令:mkdir 目录
1 | mkdir aaa 在当前目录下创建一个名为aaa的目录 |
2.3.2 删除目录或文件【删】rm
命令:rm [-rf] 目录
删除文件:
1 | rm 文件 删除当前目录下的文件 |
删除目录:
1 | rm -r aaa 递归删除当前目录下的aaa目录 |
全部删除:
1 | rm -rf * 将当前目录下的所有目录和文件全部删除 |
2.3.3 目录修改【改】mv 和 cp
一、重命名目录
1 | 命令:mv 当前目录 新目录 |
二、剪切目录
1 | 命令:mv 目录名称 目录的新位置 |
三、拷贝目录
1 | 命令:cp -r 目录名称 目录拷贝的目标位置 -r代表递归 |
2.3.4 搜索目录【查】find
1 | 命令:find 目录 参数 文件名称 |
三、文件操作命令
3.1 文件操作【增,删,改,查】
3.1.1 新建文件【增】touch
1 | 命令:touch 文件名 |
3.1.2 删除文件 【删】 rm
1 | 命令:rm -rf 文件名 |
3.1.3 修改文件【改】 vi或vim
【vi编辑器的3种模式】
基本上vi可以分为三种状态,分别是命令模式(command mode)、插入模式(Insert mode)和底行模式(last line mode),各模式的功能区分如下:
命令行模式command mode)
控制屏幕光标的移动,字符、字或行的删除,查找,移动复制某区段及进入Insert mode下,或者到 last line mode。
命令行模式下的常用命令:1
2
3
4
5【1】控制光标移动:↑,↓,j
【2】删除当前行:dd
【3】查找:/字符
【4】进入编辑模式:i o a
【5】进入底行模式::编辑模式(Insert mode)
只有在Insert mode下,才可以做文字输入,按「ESC」键可回到命令行模式。
编辑模式下常用命令:1
【1】ESC 退出编辑模式到命令行模式;
底行模式(last line mode)
将文件保存或退出vi,也可以设置编辑环境,如寻找字符串、列出行号……等。
底行模式下常用命令:1
2
3【1】退出编辑: :q
【2】强制退出: :q!
【3】保存并退出: :wq
打开文件
1 | 命令:vi 文件名 |
编辑文件
1 | 使用vi编辑器打开文件后点击按键:i ,a或者o即可进入编辑模式。 |
保存或者取消编辑
保存文件:
1 | 第一步:ESC 进入命令行模式 |
取消编辑:
1 | 第一步:ESC 进入命令行模式 |
3.1.4 文件的查看【查】
1 | 文件的查看命令:cat/more/less/tail |
3.2 权限修改
1 | rwx:r代表可读,w代表可写,x代表该文件是一个可执行文件,如果rwx任意位置变为-则代表不可读或不可写或不可执行文件。 |
四、压缩文件操作
4.1 打包和压缩
1 | Windows的压缩文件的扩展名 .zip/.rar |
4.2 解压
1 | 命令:tar [-zxvf] 压缩文件 |
五、查找命令
5.1 grep
1 | grep命令是一种强大的文本搜索工具 |
5.2 find
1 | find命令在目录结构中搜索文件,并对搜索结果执行指定的操作。 |
5.3 locate
1 | locate 让使用者可以很快速的搜寻某个路径。默认每天自动更新一次,所以使用locate 命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。如果数据库中没有查询的数据,则会报出locate: can not stat () `/var/lib/mlocate/mlocate.db': No such file or directory该错误!updatedb即可! |
5.4 whereis
1 | whereis命令是定位可执行文件、源代码文件、帮助文件在文件系统中的位置。这些文件的属性应属于原始代码,二进制文件,或是帮助文件。 |
六、su、sudo
6.1 su
1 | su用于用户之间的切换。但是切换前的用户依然保持登录状态。如果是root 向普通或虚拟用户切换不需要密码,反之普通用户切换到其它任何用户都需要密码验证。 |
6.2 sudo
1 | sudo是为所有想使用root权限的普通用户设计的。可以让普通用户具有临时使用root权限的权利。只需输入自己账户的密码即可。 |
七、系统服务
1 | service iptables status --查看iptables服务的状态 |
八、网络管理
8.1 主机名配置
1 | [root@node1 ~]# vi /etc/sysconfig/network |
8.2 IP 地址配置
1 | [root@node1 ~]# vi /etc/sysconfig/network-scripts/ifcfg-eth0 |
8.3 域名映射
1 | /etc/hosts文件用于在通过主机名进行访问时做ip地址解析之用。所以,你想访问一个什么样的主机名,就需要把这个主机名和它对应的ip地址。 |
九、定时任务指令crontab 配置
1 | crontab是Unix和Linux用于设置定时任务的指令。通过crontab命令,可以在固定间隔时间,执行指定的系统指令或shell脚本。时间间隔的单位可以是分钟、小时、日、月、周及以上的任意组合。 |
9.1 命令格式
1 | crontab [-u user] file |
9.2 配置说明、实例
1 | 命令:* * * * * command |
十、其他命令
10.1 查看当前目录:pwd
1 | 命令:pwd 查看当前目录路径 |
10.2 查看进程:ps -ef
1 | 命令:ps -ef 查看所有正在运行的进程 |
10.3 结束进程:kill
1 | 命令:kill pid 或者 kill -9 pid(强制杀死进程) pid:进程号 |
10.4 网络通信命令:
1 | ifconfig:查看网卡信息 |
10.5 配置网络
1 | 命令:setup |
10.6 重启网络
1 | 命令:service network restart |
10.7 切换用户
1 | 命令:su - 用户名 |
10.8 关闭防火墙
1 | 命令:chkconfig iptables off |
10.9 修改文件权限
1 | 命令:chmod 777 |
10.10 清屏
1 | 命令:ctrl + l |
10.11 vi模式下快捷键
1 | esc后: |
十一、Linux项目部署
11.1 安装jdk1.8
1 | 先卸载open-jdk |
11.2 安装MySQL 5.6
11.2.1 上传MySQL5.6的tar包
1 | 创建目录:mkdir /usr/local/src/mysql5.6 |
11.2.2 安装
第一步:解压
命令:tar -xvf MySQL-5.6.34-1.rhel5.x86_64.rpm-bundle.tar
第二步:检测是否已经安装了mysql
命令:rpm -qa | grep mysql
如果已经安装了,将其卸载,如:
rpm -e --nodeps mysql-libs-5.1.71-1.el6.x86_64
第三步:安装MySQL的服务端
命令:rpm -ivh MySQL-server-5.6.34-1.rhel5.x86_64.rpm
第四步:安装MySQL的客户端
命令:rpm -ivh MySQL-client-5.6.34-1.rhel5.x86_64.rpm
第五步:查看MySQL服务运行状态
命令:service mysql status
第六步:启动MySQL服务
命令:service mysql start
第七步:使用root账号登录mysql
在安装mysql server时有句提示:
注意:这个密码是不安全的,所有需要修改初始密码。
- 使用密码登录mysql账号:mysql -uroot -p
- 修改root密码:SET PASSWORD = PASSWORD(‘root’);
11.2.3 开机自动启动设置
加入到系统服务:
1 | chkconfig --add mysql |
自动启动:
1 | chkconfig mysql on |
查询列表:
1 | chkconfig |
说明:都没关闭(off)时是没有自动启动。
11.2.4 开启远程访问
登录:
1 | mysql -uroot –proot |
设置远程访问(使用root密码):
1 | grant all privileges on *.* to 'root' @'%' identified by 'root'; |
退出mysql,在centos环境下打开3306防火墙
1 | /sbin/iptables -I INPUT -p tcp --dport 3306 -j ACCEPT |
11.3 安装tomcat部署项目
准备工作:将web项目打成war包,改名为ROOT.war
11.3.1 创建ucenter用户
一般情况下,发布应用程序都不是使用root用户的,需要创建一个普通用户来发布程序;
创建ucenter用户:
1 | useradd -d /ucenter ucenter |
设置密码:
1 | passwd ucenter (密码 ucenter) |
切换用户:
1 | su - ucenter |
11.3.2 安装Tomcat
tomcat只要解压就可以使用。
1 | 1、创建web目录 |
发现无法访问:
8、防火墙打开 8080 端口
1 | /sbin/iptables -I INPUT -p tcp --dport 8080 -j ACCEPT |
9、安装成功
11.3.3 部署用户管理项目
1、上传usermanage.sql和ROOT.war到/ucenter/web
2、执行数据库脚本
cat user_manager.sql | mysql -uroot -p123456
3、部署web程序
3.1 删除webapps下的所有文件
cd /ucenter/web/usermanage/webapps
rm -rf *
3.2 拷贝ROOT.war到webapps
cp /ucenter/web/ROOT.war .
3.3 重新启动tomcat
cd ../bin/
sh startup.sh && tail -f ../logs/catalina.out
3.4 启动浏览器测试
注意事项:Centos环境下部署项目中文乱码问题解决方案
今天在一台新的CentOS机器上使用c3p0连接池操作mysql数据库出现中文乱码问题,具体表现为:查询时无中文乱码问题,写数据时中文乱码,查看了机器上数据库字符集也是UTF8,应该不会出现中文乱码才对,最后在c3p0配置文件中 jdbcUrl后加上:?useUnicode=true&characterEncoding=UTF8 中文就不会乱码了。
【C3P0配置文件】
1 |
|
11.4 Linux下使用FastDFS
相关的安装包我打包到云盘上了,链接:https://pan.baidu.com/s/13NDYYil4mgLhkb5CYsc2Ww 提取码:66tn
单节点FastDFS
整个安装过程非常复杂,很容易出错,建议进行多次备份。
我们这里不打算安装多台虚拟机,因此会把tracker和storage都安装在一起。
11.4.1 安装gcc
GCC用来对C语言代码进行编译运行,使用yum命令安装:
1 | yum -y install gcc |
后面会用到解压命令(unzip),所以这里可以用yum把unzip 也装一下
1 | yum install -y unzip zip |
11.4.2 安装libevent
1 | yum -y install libevent |
11.4.3 安装libfastcommon-master
解压刚刚上传的libfastcommon-master.zip
1 | unzip libfastcommon-master.zip |
进入解压完成的目录
1 | cd libfastcommon-master |
编译并且安装:
1 | ./make.sh |
11.4.4 安装fastdfs
1 | tar -zxvf FastDFS_v5.08.tar.gz |
如果安装成功,会看到/etc/init.d/下看到提供的脚本文件:
1 | ll /etc/init.d/ | grep fdfs |
fdfs_trackerd
是tracker启动脚本fdfs_storaged
是storage启动脚本
能够在 /etc/fdfs/ 目录下看到默认的配置文件模板:
1 | ll /etc/fdfs/ |
tarcker.conf.sample
是tracker的配置文件模板storage.conf.sample
是storage的配置文件模板client.conf.sample
是客户端的配置文件模板
11.4.5 配置并启动tracker服务
1)首先将模板文件复制
1 | cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf |
2)修改复制后的配置文件:
1 | vim /etc/fdfs/tracker.conf |
修改的内容如下:
1 | base_path=/项目名/tracker # 存储日志和数据的根目录 |
3)新建目录:
1 | mkdir -p /项目名/tracker |
注意:关闭防火墙:
1 | chkconfig iptables off |
4)启动和停止
1 | service fdfs_trackerd start # 启动fdfs_trackerd服务,停止用stop |
检查FastDFS Tracker Server是否启动成功:
1 | ps -ef | grep fdfs_trackerd |
设置tracker服务开机启动:
1 | chkconfig fdfs_trackerd on |
11.4.6 配置并启动storage服务
1)首先将模板文件复制
1 | cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf |
2)修改复制后的配置文件:
1 | vim /etc/fdfs/storage.conf |
修改的内容如下:
1 | base_path=/项目名/storage # 数据和日志文件存储根目录 |
3)新建目录:
1 | mkdir -p /项目名/storage |
4)启动和停止
1 | service fdfs_storaged start # 启动fdfs_storaged服务,停止用stop |
设置storage服务开机启动:
1 | chkconfig fdfs_storaged on |
11.5 安装fastdfs-nginx-module
11.5.1 解压
1 | tar -zxvf fastdfs-nginx-module_v1.16.tar.gz |
11.5.2 修改config
1)进入src目录
1 | cd fastdfs-nginx-module/src/ |
2)编辑config
1 | vim config |
使用以下底行命令:
1 | :%s+/usr/local/+/usr/+g |
将所有的/usr/local替换为 /usr,这个才是正确的目录:
11.5.3 配置nginx与FastDFS关联配置文件
复制 fastdfs-nginx-module 源码中的配置文件到/etc/fdfs 目录, 并修改
cp /usr/local/项目名/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs/
vi /etc/fdfs/mod_fastdfs.conf
修改以下配置:
1 | connect_timeout=10 # 客户端访问文件连接超时时长(单位:秒) |
复制 FastDFS 的部分配置文件到/etc/fdfs 目录
1 | cd /usr/local/项目名/FastDFS/conf/ |
11.6 安装Nginx的插件
11.6.1 如果没有安装过nginx
1、安装nginx的依赖库
1 | yum -y install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel |
2、解压安装包
1 | tar -zxvf nginx-1.10.0.tar.gz |
3、配置nginx安装包,并指定fastdfs-nginx-model
1 | cd nginx-1.10.0 |
4、编译并安装
1 | make && make install |
11.6.2 如果已经安装过nginx
1、 进入nginx目录:
1 | cd /usr/local/项目名/nginx-1.10.0/ |
2、 配置FastDFS 模块
./configure –prefix=/opt/nginx –sbin-path=/usr/bin/nginx –add-module=/usr/local/项目名/fastdfs-nginx-module/src
注意:这次配置时,要添加fastdfs-nginx-moudle模块
3、编译,注意,这次不要安装(install)
1 | make |
4、替换nginx二进制文件:
备份:
1 | mv /usr/bin/nginx /usr/bin/nginx-bak |
用新编译的nginx启动文件替代原来的:
1 | cp objs/nginx /usr/bin/ |
11.6.3 启动nginx
配置nginx整合fastdfs-module模块
我们需要修改nginx配置文件,在/opt/nginx/config/nginx.conf文件中:
1 | vim /opt/nginx/conf/nginx.conf |
将文件中,原来的server 80{ …} 部分代码替换为如下代码:
1 | server { |
启动nginx:
1 | nginx # 启动nginx |
可通过ps -ef | grep nginx查看nginx是否已启动成功
11.6.4 设置nginx开机启动
1 | #!/bin/sh |
修改文件权限,并加入服务列表
1 | # 修改权限 |
设置开机启动
1 | chkconfig nginx on |
11.7 安装Elasticsearch
需要虚拟机JDK1.8及以上
11.7.1 新建一个用户leyou
出于安全考虑,elasticsearch默认不允许以root账号运行。
创建用户:
1 | useradd leyou |
设置密码:
1 | passwd leyou |
切换用户:
1 | su - leyou |
11.7.2 上传安装包,并解压
我们将安装包上传到:/home/leyou目录
解压缩:
1 | tar -zxvf elasticsearch-6.2.4.tar.gz |
我们把目录重命名:
1 | mv elasticsearch-6.3.0/ elasticsearch |
进入,查看目录结构:
11.7.3 修改配置
我们进入config目录:cd config
需要修改的配置文件有两个:
1、jvm.options
Elasticsearch基于Lucene的,而Lucene底层是java实现,因此我们需要配置jvm参数。
编辑jvm.options:
1 | vim jvm.options |
默认配置如下:
1 | -Xms1g |
内存占用太多了,我们调小一些:
1 | -Xms512m |
2、elasticsearch.yml
1 | vim elasticsearch.yml |
修改数据和日志目录:
1 | path.data: /home/leyou/elasticsearch/data # 数据目录位置 |
我们把data和logs目录修改指向了elasticsearch的安装目录。但是这两个目录并不存在,因此我们需要创建出来。
进入elasticsearch的根目录,然后创建:
1 | mkdir data |
修改绑定的ip:
1 | network.host: 0.0.0.0 # 绑定到0.0.0.0,允许任何ip来访问 |
默认只允许本机访问,修改为0.0.0.0后则可以远程访问
11.7.4 运行
进入elasticsearch/bin目录,可以看到下面的执行文件:
然后输入命令:
1 | ./elasticsearch |
或者后台运行:
1 | ./elasticsearch -d |
11.7.5 错误1:内核过低
修改elasticsearch.yml文件,在最下面添加如下配置: 然后重启
1 | bootstrap.system_call_filter: false |
11.7.6 错误2:文件权限不足
我们用的是leyou用户,而不是root,所以文件权限不足。
首先用root用户登录。直接输入exit命令
然后修改配置文件:
1 | vim /etc/security/limits.conf |
添加下面的内容:
1 | * soft nofile 65536 |
11.7.7 错误3:线程数不够
[1]: max number of threads [1024] for user [leyou] is too low, increase to at least [4096]
继续修改配置:
1 | vim /etc/security/limits.d/90-nproc.conf |
修改下面的内容:
1 | soft nproc 1024 |
改为
1 | soft nproc 4096 |
11.7.8 错误4:进程虚拟内存
[3]: max virtual memory areas vm.max_map_count [65530] likely too low, increase to at least [262144]
vm.max_map_count:限制一个进程可以拥有的VMA(虚拟内存区域)的数量,继续修改配置文件, :
vim /etc/sysctl.conf
添加下面内容:
1 | vm.max_map_count=655360 |
然后执行命令:
1 | sysctl -p |
11.7.9 重启终端窗口
所有错误修改完毕,一定要重启你的 Xshell终端,否则配置无效。
11.8 安装RabbitMQ
1 | cd /usr/local/myapp |
11.8.1 安装Erlang
1、在线安装
1 | yum install esl-erlang_17.3-1~centos~6_amd64.rpm |
2、离线安装
依次执行命令:
1 | 1)rpm -ivh esl-erlang-17.3-1.x86_64.rpm --force --nodeps |
1 | 2)rpm -ivh esl-erlang_17.3-1~centos~6_amd64.rpm --force --nodeps |
1 | 3)rpm -ivh esl-erlang-compat-R14B-1.el6.noarch.rpm --force --nodeps |
11.8.2 安装RabbitMQ
安装:
1 | rpm -ivh rabbitmq-server-3.4.1-1.noarch.rpm |
11.8.3 设置配置文件
1 | cp /usr/share/doc/rabbitmq-server-3.4.1/rabbitmq.config.example |
开启用户远程访问
1 | vi /etc/rabbitmq/rabbitmq.config |
注意要去掉后面的逗号。
11.8.4 启动、停止
1 | service rabbitmq-server start |
11.8.5 开启web界面管理工具
1 | rabbitmq-plugins enable rabbitmq_management |
11.8.6 设置开机启动
1 | chkconfig rabbitmq-server on |
11.8.7 防火墙开放15672端口
1 | /sbin/iptables -I INPUT -p tcp --dport 15672 -j ACCEPT |
11.9 redis安装和配置
11.9.1 安装
解压
1 | tar -xvf redis-4.0.9.tar.gz |
编译安装
1 | mv redis-4.0.9 redis |
11.9.2 配置
修改安装目录下的redis.conf文件
1 | vim redis.conf |
修改以下配置:
1 | #bind 127.0.0.1 # 将这行代码注释,监听所有的ip地址,外网可以访问 |
11.9.3 启动或停止
redis提供了服务端命令和客户端命令:
redis-server 服务端命令,可以包含以下参数: start 启动 stop 停止
redis-cli 客户端控制台,包含参数: -h xxx 指定服务端地址,缺省值是127.0.0.1 -p xxx 指定服务端端口,缺省值是6379
11.9.4 设置开机启动
- 输入命令,新建文件
1 | vim /etc/init.d/redis |
输入下面内容:
1 | #!/bin/sh |
然后保存退出
注意:以下信息需要根据安装目录进行调整:
1 | EXEC=/usr/local/bin/redis-server # 执行脚本的地址 |
2)设置权限
1 | chmod 755 /etc/init.d/redis |
3)启动测试
1 | /etc/init.d/redis start |
启动成功会提示如下信息:
1 | Starting Redis server... |
4)设置开机自启动
1 | chkconfig --add /etc/init.d/redis |
————————————————
版权声明:本文为CSDN博主「Demon_gu」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_23329167/article/details/83856430