29 Linux基本命令

本文介绍如何使用Mac自带的终端工具连接服务器,无需额外软件。此外,还提供了Linux系统的基本操作指南,涵盖文件管理、编辑器使用、权限设置等关键知识点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mac不用安装xshell,secureCRT等工具用mac的终端就可以连接服务器。

1、打开终端,输入sudo su - 回车进入根目录

2、然后输入:ssh 服务器用户名@ip (如:ssh wnei@000.000.000.00)如图中1

3.回车,到这会让你输入yes或者no来确认是否连接,输入yes回车(若登录过一次就如上图不会出现)

4.然后输入服务器用户的密码回车 如图中2

5.到此进入的是你在服务器上的账户的目录,即为连接成功 如图中3,那么你就可以愉快的在上面玩耍了。

 

从Linux上下载报表xls文件到本地

sz 文件名 

Ssh的默认传输保存位置在Options-Session Options中的X/Y/Zmodem中查看设置。

 

1.1      Linux的安装:

1.1.1    CentOS的安装

参考《CentOS6详细安装文档.doc》

1.1.2    Linux的目录结构:

root管理员的home目录root
其他用户的home目录home目录中

 

1.1      Linux的常用命令

 

1.1.1    切换目录命令cd:

使用

cd app     切换到app目录

cd .. 切换到上一层目录

cd /         切换到系统根目录

cd ~        切换到用户主目录

cd -         切换到上一个所在目录

 

回到根目录

 

1.1.1    列出文件列表:ls ll dir(*****)

ls(list)用来显示当前目录下的内容。配合参数的使用,能以不同的方式显示目录内容。

    格式:ls[参数] [路径或文件名]

 

常用:

在linux中以 . 开头的文件都是隐藏的文件

 

* ls

* ls -a 显示所有文件或目录(包含隐藏的文件)

* ls -l 缩写成ll

1.1.2    创建目录和移除目录:mkdir rmdir

mkdir(make directory)命令可用来创建子目录。

mkdir app   在当前目录下创建app目录

mkdir –p app2/test   级联创建aap2以及test目

 

rmdir(remove directory)命令可用来删除“空”的子目录:

rmdir app   删除app目录

rm           可以删除内含多级目录的文件夹或者文件

创建多级目录的指令

查询mkdir有哪些方法,如何使用,, 按q退出查看指导

 

 

1.1.1    浏览文件

【cat、more、less】

用于查看tomcat的启动信息

cat

用于显示文件的内容。

格式:cat[参数]<文件名>

 

* cat yum.conf

 

注意使用tab的自动补全名字功能补全要查看的文件名,节省时间

 

more

一般用于要显示的内容会超过一个画面长度的情况。按空格键显示下一个画面。

回车显示下一行内容。

按 q 键退出查看。

* more yum.conf

   *空格显示下一页数据  回车显示下一行的数据

 

less

用法和more类似,不同的是less可以通过PgUp、PgDn键来控制。

    *less yum.conf

       * PgUpPgDn 进行上下翻页.

 

【tail】

tail命令是在实际使用过程中使用非常多的一个命令,它的功能是:用于显示文件后几行的内容。

用法:

tail -10 /etc/passwd    查看后10行数据

 

 

tail -f catalina.log   动态查看日志(*****)

ctrl+c 结束动态查看

 

 

1.1.2    文件操作:

1.1.2.1  【rm】删除文件

 

用法:rma.txt   删除a.txt文件

删除需要用户确认,y/n

 

rm 删除不询问

rm -f a.txt    不询问,直接删除

 

rm 删除目录

rm -r a   递归删除删除多级的目录

 

不询问递归删除(慎用)谨慎使用

rm -rf a    不询问递归删除   

rm -rf *     删除所有文件

rm -rf /*      自杀   没办法fuck,只能重装

 

 

创建txt文件的命令:vim a.txt     完成内容编辑后按一下一下esc键再输入:wq回车完成编辑回到命令行

 

 

1.1.2.2  【cp、mv】复制./移动文件

使用cp命令时将一个文件复制成另一个文件或到某目录时,需要指定源文件名与目标文件名或目录。

cp a.txt b.txt    将a.txt复制为b.txt文件

cp a.txt ../    将a.txt文件复制到上一层目录中

 

mv 移动或者重命名

mv a.txt ../    将a.txt文件移动到上一层目录中

mv a.txt b.txt    将a.txt文件重命名为b.txt

 

1.1.2.3  【tar】(打包或解压:重要)

tar命令位于/bin目录下,它能够将用户所指定的文件或目录打包成一个文件,但不做压缩。

 

一般Linux上常用的压缩方式是选用tar将许多文件打包成一个文件,再以gzip压缩命令压缩成xxx.tar.gz(或称为xxx.tgz)的文件。

 

常用参数:

-c:创建一个新tar文件

-v:显示运行过程的信息

-f:指定文件名

-z:调用gzip压缩命令进行压缩

-t:查看压缩文件的内容

-x:解开tar文件

 

 

1.1.1.1.1       打包:

 

tar –cvf  xxx.tar ./*  

打包并且压缩:

tar –zcvf  xxx.tar.gz ./*

 

1.1.1.1.2       解压

tar –xvf  xxx.tar

tar –xvf  xxx.tar.gz  -C  /usr/aaa    //解压到指定的路径,前提是这个路径已经存在

/user/aaa是从根目录开始的,   ./是从该级目录开始的.

 

那压缩了的文件怎么解压呢?

1.1.1.2  【grep】命令

查找符合条件的字符串。

用法: grep [选项]... PATTERN [FILE]...

示例:

grep lang anaconda-ks.cfg  在文件中查找lang

grep lang anaconda-ks.cfg –color 高亮显示

 

-A5表示查找到的关键字的后五行 ,

-B3表示前3行  

 

用于tomcat报错的时候快速报错的查找

 

1.1.1    其他常用命令

1.1.1.1  【pwd】显示当前所在目录

 

 

1.1.1.2  【touch】创建一个空文件  *  touch  a.txt

只要ll查询显示出来的字段前面有个-横杠表示是文件, Linux中文件是没有扩展名之分的.

 

1.1.1.3  【ll -h】友好显示文件大小

 

ll –h   可以将文件的大小显示在展示列表中.

 

1.1.1.4  【wget】下载资料

* wgethttp://nginx.org/download/nginx-1.9.12.tar.gz

1.2      Vi和Vim编辑器

1.2.1    Vim编辑器:

在Linux下一般使用vi编辑器来编辑文件。

vi既可以查看文件也可以编辑文件。

 

三种模式:命令行、插入、底行模式。

切换到命令行模式:按Esc键;

切换到插入模式:按 i 、o、a键;

    i 在当前位置生前插入

    I 在当前行首插入

    a 在当前位置后插入

    A 在当前行尾插入

    o 在当前行之后插入一行

    O 在当前行之前插入一行

 

切换到底行模式:按 :(冒号);

更多详细用法,查询文档《Vim命令合集.docx》和《vi使用方法详细介绍.docx》

 

 

打开文件:vim file

退出:esc à :q   不做保存操作.

修改文件:输入i进入插入模式

保存并退出:escà:wq

 

不保存退出:escà:q!

 

3中进入插入模式:

i:在当前的光标所在处插入

o:在当前光标所在的行的下一行插入

a:在光标所在的下一个字符插入

 

快捷键:

dd – 快速删除一行

R – 替换

 

复制一行   yy

粘贴      p

1.2.2    重定向输出>和>>

> 重定向输出,覆盖原有内容;

>> 重定向输出,又追加功能;

示例:

cat /etc/passwd > a.txt  将passwd文件的内容输出定向到a.txt中

cat /etc/passwd >> a.txt  输出并且内容追加到a.txt

cllsdfefij 2> 1.txt    2>表示错误的重定向

 

ifconfig > ifconfig.txt

1.2.3    管道 |

管道是Linux命令中重要的一个概念,其作用是将一个命令的输出用作另一个命令的输入

示例

ll --help | more  分页查询帮助信息    按空格翻页

cat /etc/passwd.txt | wc   显示passwd.txt文件有的行数

cat /etc/passwd.txt | grep user1   查出文件包含‘user1’那行

ls -l | grep "^-"    只列出以-开头的文件,其中^为正则表达式符号表示字符串的开始位置,

同理  ls -l | grep "^d"  表示只列出目录,也就是文件夹directory

ls -l | grep "^-" | wc -l   将所有-打头的文件列出来,数一数有多少个文件。

ps ef | grep java  查询名称中包含java的进程

 

ifconfig | more

cat index.html | more

 

ps –ef | grep aio

找到相关的进程,然后可以执行操作

ps –fu    查看前台运行的进程

kill -9 2085

1.2.4    &&命令执行控制:

命令之间使用&& 连接,实现逻辑与的功能。

 

只有在 &&左边的命令返回真(命令返回值$? == 0),&& 右边的命令才会被执行。 

 

只要有一个命令返回假(命令返回值 $? == 1),后面的命令就不会被执行。

 

mkdir test && cd test

 

 

&&有短路的效果 , 但是使用单个&就没有短路的效果了, 即时前面的语句错了也不会影响后面的语句执行.

如上图所示, 可以多个&&一起执行.

1.1.1    网络通讯命令

ifconfig 显示或设置网络设备。

ifconfig 显示网络设备

ifconfig eth0 up 启用eth0网卡

ifconfig eth0 down  停用eth0网卡

ping  探测网络是否通畅。

ping 192.168.0.1

netstat 查看网络端口。

netstat -an | grep3306 查询3306端口占用情况,(查询指定端口号的占用情况,查到了表示已占用)

1.1.2    系统管理命令

date 显示或设置系统时间

date 显示当前系统时间

date -s “2014-01-01 10:10:10“  设置系统时间

df 显示磁盘信息

df –h  友好显示大小

free 显示内存状态

free –m 以mb单位显示内存组昂头

top 显示,管理执行中的程序

load average  负载:超过10或者20就会比较卡了.

 

 

clear 清屏幕

 

ps 正在运行的某个进程的状态

ps –ef  查看所有进程

ps –ef | grep ssh 查找某一进程

kill 杀掉某一进程

kill 2868 杀掉2868编号的进程

kill -9 2868  强制杀死进程

 

du 显示目录或文件的大小。

du –h显示当前目录的大小

 

who 显示目前登入系统的用户信息。

 

hostname 查看当前主机名

修改:vi/etc/sysconfig/network

 

uname 显示系统信息。

uname -a 显示本机详细信息。

依次为:内核名称(类别),主机名,内核版本号,内核版本,内核编译日期,硬件名,处理器类型,硬件平台类型,操作系统名称

1.2      Linux的用户和组

1.2.1    用户的管理

Useradd命令添加一个用户

useradd test 添加test用户

useradd test -d  /home/t1 指定用户home目录

 

passwd命令设置、修改密码

passwd  test  为test用户设置密码

 

切换登录:

ssh -l test -p 22 192.168.19.128

用户名为test , 端口号为22 ,  IP  

 

su – 用户名 (注意-后有空格)

 

userdel 删除一个用户

userdel test 删除test用户(不会删除home中的目录)

userdel r  test 删除用户以及home中的目录

1.2.2    组管理:

当在创建一个新用户user时,若没有指定他所属于的组,就默认建立一个和该用户同名的私有组

 

创建用户时也可以指定所在组

 

创建组的命令groupadd 

groupadd public  创建一个名为public的组

useradd u1 –gpublic 创建用户指定组

 id      查看用户信息:

删除组的命令groupdel,如果该组有用户成员,必须先删除用户才能删除组。

groupdel public

 

1.2.3    id,su命令

【id命令】

功能:查看一个用户的UID和GID

用法:id [选项]... [用户名]

直接使用id

直接使用id 用户名

 

【su命令】

功能:切换用户。

用法:su [选项]... [-] [用户 [参数]... ]

示例:

su u1 切换到u1用户

su - u1 切换到u1用户,并且将环境也切换到u1用户的环境(推荐使用)

 

【账户文件】

/etc/passwd 用户文件

/etc/shadow 密码文件

/etc/group 组信息文件

 

【用户文件】

root:x:0:0:root:/root:/bin/bash

账号名称:           在系统中是唯一的

用户密码:           此字段存放加密口令

用户标识码(User ID): 系统内部用它来标示用户

组标识码(Group ID):  系统内部用它来标识用户属性

用户相关信息:           例如用户全名等

用户目录:           用户登录系统后所进入的目录

用户环境:             用户工作的环境

 

【密码文件】

shadow文件中每条记录用冒号间隔的9个字段组成.

用户名:用户登录到系统时使用的名字,而且是惟一的

口令:  存放加密的口令

最后一次修改时间:  标识从某一时刻起到用户最后一次修改时间

最大时间间隔:  口令保持有效的最大天数,即多少天后必须修改口令

最小时间间隔:    再次修改口令之间的最小天数

警告时间:从系统开始警告到口令正式失效的天数

不活动时间:       口令过期少天后,该账号被禁用

失效时间:指示口令失效的绝对天数(从1970年1月1日开始计算)

标志:未使用

 

【组文件】

root:x:0:

组名:用户所属组

组口令:一般不用

GID:组ID

用户列表:属于该组的所有用户

1.1      Linux的权限命令

1.1.1    文件权限

'

'

 

1.1.1    Linux三种文件类型:

 

普通文件: 包括文本文件、数据文件、可执行的二进制程序文件等。

目录文件: Linux系统把目录看成是一种特殊的文件,利用它构成文件系统的树型结构。 

设备文件: Linux系统把每一个设备都看成是一个文件

1.1.2    文件类型标识

普通文件(-

目录(d

符号链接(l

* 进入etc可以查看,相当于快捷方式

字符设备文件(c)

块设备文件(s)

套接字(s)

命名管道(p)

1.1.3    文件权限管理:

chmod 变更文件或目录的权限。

chmod 755 a.txt

755分别表示三种用户分别具有的权限值 .

 

chmod u=rwx,g=rx,o=rx a.txt

u代表当前用户的权限, g代表组具有的权限  , o代表其他用户的权限.

 

chmod 000 a.txt  / chmod 777 a.txt

 

chown 变更文件或目录改文件所属用户和组

chown u1:public a.txt    :只会变更当前的目录或文件的所属用户和组

chown -R u1:public dir  :变更目录中的所有的子目录及文件的所属用户和组

 

 

目标:把项目发布到Linux上运行起来.

当命令行前面没有用户名的时候只有一个>符号, 单引号回车恢复正常.

 

项目发布到Linux系统中后,动态查看日志的流程:

进入到tomcat的log目录下,动态显示catalina.out文件

 

[root@dcy logs]# cd  /usr/local/tomcat/apache-tomcat-7.0.57/logs/

[root@dcy logs]# ll

 [root@dcylogs]# tail  -f  catalina.out

命令 --help    查看某命令的使用帮助

ls -l 查看含文件类型的详细文件列表

rm -rf directory1    递归+强制 删除目录1

查看文件内容:

  cat 1.txt

  more 1.txt

  grep six 1.txt  找到1.txt中包含‘six'字符的那行数据

  head -3 1.txt   文件头3行

  tail -4 1.txt     文件尾4行

 

vi命令:

  vi 1.txt  进入编辑1.txt文件 、刚进入是命令模式化,手动进入编辑模式

  i(当前位置) ,o(下面行), shift+o(上面行) ,插入

  按esc 退出编辑模式,进入命令模式

  :开始输入命令

  :wq  保存write并退出quit ,

  :q!  不保存并退出

 

find / -name bjsxt   查找/目录下  名字 为 bjsxt的文件,可以使用*通配

echo $PATH   查看环境变量配置

 

ln的链接分软链接和硬链接两种:

  ln 1.txt  2 将2链接到1.txt (相当于将1.txt文件复制一份为2,但是编辑1.txt后2会同步变化,编辑2后1.txt也会变化。删除1.txt后2任然可以编辑、使用)

  ln -s 1.txt  3 将3链接到1.txt ,ls -l后显示为3->1.txt 。(1.txt删除后3将无法使用)

1、软链接就是:“ln –s 源文件 目标文件”,只会在选定的位置上生成一个文件的镜像,不会占用磁盘空间,类似与windows的快捷方式。
2、硬链接ln源文件目标文件,没有参数-s, 会在选定的位置上生成一个和源文件大小相同的文件,无论是软链接还是硬链接,文件都保持同步变化。

 

Linux内核执行命令是通过shell间接执行的,所以我们编写的代码都是某种shell,比如linux命令前为#时是bash(b,again,shell)

  

  csh 进入c shell模式 

  exit 退出当前shell模式返回上一次的shell模式。

 

su testuser2 切换用户为testuser2 。 exit 返回刚才的用户。

 

文件权限、文件所有者:

drwxrwxrwx  开头的第一个字母:-表示是文件,d表示是目录,l表示是链接ln

rwx三个为一组代表某种人的权限,共分为三种人的权限:(文件所有者)(文件所有者同组的人)(其他人)所拥有的权限

chmod +x 1.txt   为三组人都添加1.txt的x的执行权限

chmod u+x 1.txt   只为当前用户添加1.txt的x的执行权限

chmod g+x  1.txt   为属于该组的人添加1.txt的x的执行权限

chmod o+x 1.txt    只为其他组的人添加1.txt的x的执行权限

更直接间接的写法:chmod 777  1.txt   将1.txt文件的权限修改为rwxrwxrwx 。因为rwx分别对应4、2、1,三位数。

chown testuser2 1.txt 更改1.txt文件的所有者为testuser2,ls -l 列表中权限后面第二列就是所有者。    

 

dmesg  显示启动信息

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值