Linux之快速入门

一、Linux目录结构

从Windows转到Linux最不习惯的是什么:

目录结构

Windows会分盘,想怎么放东西就怎么放东西,好处自由,缺点容易乱

Linux有自己的目录结构,不能随随便便放东西

  • /:根目录
  • /bin:二进制文件,放常用的命令
  • /boot:启动时使用的核心文件(连接、镜像文件,跟系统环境有关,不会动它)
  • /dev:Device设备缩写,放网卡和硬件设备(存外部设备)

注:Windows有盘,显示图标,Linux所有设备都是文件(一切接是文件)

  • /etc:放配置文件(环境变量)
  • /home:放自己的资料

注:(常用)创建用户,这个用户会默认在Windows下面创建一个更你的用户名同名的目录,这个目录就是我放资料的地方,不能放在别人目录下,因为Linux是多用户多任务操作系统,同时存有很多到服务器上去,找就是你创建的用户名,可以改,但是不建议

  • /lib:是动态连接共享库(架包\使用的基础库)
  • /lost+found丢失并且找到了:一般是空的,非法关机,就会存放文件,便与系统修复
  • /media:自动设备(u盘..)识别并挂载到上面去

注:Windows插u盘自动识别(自动挂载),双击打开(自动挡),Linux需要手动挂载(手动挡)

  • /mnt:临时挂载文件系统(与/media有点一样)
  • /opt:放第三方服务(本来没有提供的)
  • /proc:进程运行,临时产生资源放这里面,是伪文件系统(不会保存到磁盘里,但是在目录里可以看见他)看这个目录,可以窥探这个软件是怎么运行
  • /root:管理员的家

注:一般进不到这里,没有哪个权限,知道密码,会隔一段时间就换的,学进来是方便看

  • /sbin:超级管理员的二进制文件
  • /selinux:存放相关文件(安全机制,机制很复杂,相当于防火墙)
  • /srv:存放服务启动后需要提取的数据(系统自己在用)
  • /sys:系统文件(2.6内核新变化)
  • /tmp:存放临时文件

注:自己放的文件可以删和改,别人的不行

  • /use:(经常用)本地安装存放的地方
  • /usr/bin:就是bin目录
  • /usr/sbin:就是sbin目录
  • /usr/src:存放内核源码,我们看不见
  • (/usr/local:软件保存的位置)
  • /var:存放可变文件,如:日志每天都在加
  • /run:临时文件系统,重启会被清除(有些明明前几天还有用,过几天再开机就不能用了)

注:服务器为了性能好,系统会一周自动重启(重启在晚上)一遍,写一个脚本

二、常见命令

1、#与$提示符的区别:

#:root用户   $普通用户

运行的是不一样的

从root用户切换到普通用户,不需要密码,从普通用户切换到root要(高权限到低权限,低权限到高权限)

 2、su :切换用户

3、查看ip地址

ifconfig  /ip a :

注:不是默认有的,下载软件包,要运行yum install net-tools

  • eno1: 代表由主板bios内置的网卡
  • ens1:代表主板bios内置的PCI_E网卡
  • enp2s0: PCI-E独立网卡
  • eth0: 如果以上都不用,则返回默认的网卡名

ens33则属于第二种类型,即说明你的网卡是内置的PCI-E网卡,
这是由网卡特性命名的可以在  /etc/sysconfig/network-scripts/ifcfg-ens33修改名字

4、 cd 

cd 目录名 进入目录
cd .. 返回上级目录
cd ~ 进入当前用户的home目录 

5、目录查看 

ls 显示当前目录下的所有文件及子目录(看文件名)

ls -all :查看所有文件(隐藏文件一起显示出来)
ll 以详细信息的方式展示当前目录下的文件及子目录(详细)
dir 显示当前目录下的所有文件
pwd 显示当前路径
clear 清空屏幕显示

表示类型:

l:链接文件

d:目录

-:文件

rwx  所有者  rwx 所属组  rwx 其他人   777(二的二次方 4  二的一次方2   二的零次方1  )

r 读 w 写 x 执行(二进制文件和脚本)

注:目录有x代表可以进入,txt给执行权限也没用

隐藏文件

Windows

显示隐藏文件

隐藏文件

Linux:

显示隐藏文件:ls -all 

隐藏文件:文件以点开头

6、 查看文件内容

cat 只看不改
vi或vim 可看可编辑

7、创建目录及文件 

①mkdir 创建目录,
语法: mkdir -选项 -参数   /  mkdir+(名字)
选项:

  1. -m 创建目录同时设置权限
  2. mkdir -m 777 test

  3. -p 如果上级目录没有创建,即创建输入路径上的所有目录(一次性创建多级目录)
  4. mkdir -p /a/b/c

②vi +没有创建过的名字

注:也是打开文件,+创建过的文件,容易犯错地方

③touch 创建文件

④echo 重定向创建文件(不仅把文件创建了,还写了内容)

echo 'abc'> bb.txt

追加:上面会覆盖

echo 'abc'>> bb.txt

8、复制

cp 复制
示例:

  • 将文件cangls复制奥tmp目录下
    cp cangls /tmp/

  • 复制目录:将目录/root/movie下的所有内容, 复制到 tmp目录下(注意:-r 参数有递归复制的意思)
    cp -r /root/movie/ /tmp/

9、 移动或重命名

mv 文件名   文件名---->重命名

mv 文件名  目录---> 移动

语法:mv [options] source dest
参数说明:
-i 若指定目录已有同名文件, 则先询问是否覆盖旧文件,(i有交互式,询问是否覆盖,默认不用加)
-f 在mv操作要覆盖某已有的目标文件时不给任何提示,直接覆盖(强制性)。

10、其他

reboot 重启系统
shutdown -r now 重启
shutdown -h row 关机
cat /etc/issue 查看当前正在运行的ubuntu的版本号

11、 tar 

命令格式: tar [参数] 文件
常用参数:对于顺序没有要求
x: 从压缩的文件中提取文件 (解压)
c: 建立新的压缩文件(加压)
t:显示压缩的文件(不解压只看)
v: 显示操作过程
z: 通过gzip指令来处理备份文件

示例:
tar -czvf test.tar.gz a.c 作用: 压缩 a.c文件为test.tar.gz

tar -tzvf test.tar.gz 作用: 列出test.tar.gz中包含的文件。

tar -xzvf test.tar.gz 作用: 解压文件

tar --exclude=abc/1.txt -zcvf abc.tgz abc 作用: 将文件 abc 进行压缩时,排除1.txt,压缩后的文件名为 abc.tgz(选择性压缩,不压全部)

 12、which

查找可执行文件的位置
示例: which ifconfig

13、 whereis

查找文件的位置

14、 find 

注:find很强大,但是一般不会在白天用,扫磁盘的找,然而服务器磁盘特别大,占资源,用户在频繁访问系统,会导致慢和卡


查找文件或目录
格式: find [位置] [选项] 文件名 -print
示例:

  • 查找etc目录中,所有文件名以host开头的文件。
    find /etc -name 'host*'

  • 查找当前用户的home目录中所有的log文件
    find ~ -name "*.log" -print

  • 查找当前目录及子目录中文件名以一个大写字母开头的文件
    find . -name "[A-Z]*" -print

  • 从根目录查找文件名为test开头的所有文件
    find / -name "test*" -print

  • 当前目录下查找文件权限位为755的文件,即文件属主可以读、写、执行,其他用户可以读、执行的文件
    find . -perm 755 -print

  • 在$HOME目录中查找文件属主为test的文件 
    find ~ -user test -print

  • 查找属主帐户已经被删除的文件,可以使用-nouser选项。在/home目录下查找所有的这类文件
    find /home -nouser -print

  • 在/apps目录下查找属于gem用户组的文件
    find /apps -group gem -print

  • 查找没有有效所属用户组的所有文件
    find / -nogroup -print

应用:今天对文件进行修改,但是忘记了,按时间查

  • 从根目录开始查找5天内被更改的文件
    find / -mtime -5 -print

  • 在目录/etc中查找3日之前更改的文件
    find /etc -mtime +3 -print

  • 在/etc目录下查找所有的目录
    find /etc -type d -print

  • 在/etc目录下查找所有的符号链接文件
    find /etc -type l -print

16、chmod

改变文件的存取权限
命令格式:
chmod [options] mode files

mode:

  • u 表示该文件的拥有者,g 表示与该文件的拥有者属于同一个群体(group)者,o 表示其他以外的人,a 表示这三者皆是
    • 表示增加权限、- 表示取消权限、= 表示唯一设定权限
  • r 表示可读取,w 表示可写入,x 表示可执行

options:

  • -c : 若该文件权限确实已经更改,才显示其更改动作
  • -f: 文件权限无法修改,不显示错误信息
  • -r: 对当前目录下的所有文件和子目录进行递归修改

示例:

  • 给file文件的所有者增加可执行权限
    chmod u+x file(加权限)

  • 给file的所有者分配读、写、执行(7)的权限,给file的所在组分配读、执行(5)的权限,给其他用户分配执行(1)的权限
    第一种方式: chmod 751 file
    第二种方式: chmod u=rwx,g=rx,o=x file

  • 为所有用户分配读权限
    chmod =r file
    chmod a-wx,a+r file
    这两种命令作用相同

  • 递归地给directory目录下所有文件和子目录的所有者分配读的权限
    chmod -r u+r directory

三、vim的基本使用

i 进入编辑模式,vim打开文件后,默认在命令模式,点击i键方可进入编辑模式
esc 点击esc键退出编辑模式,这是可以输入':'输入命令。

符号 意义
i 进入编辑模式,vim打开文件后,默认在命令模式,点击i键方可进入编辑模式
esc 退出编辑模式,进入命令模式
:w 写入
:q 退出,如果修改了内容则这种不能退出,如果需要强制退出则使用q!
:wq 写入并退出
:q! 强制退出,不写入
dd 删除当前行(编辑模式下)
ndd 删除n行(编辑模式下)
/string 查找(搜索字符串(编辑模式下),按n查找下一个,N上一个,/str$表示匹配行尾的str, 在查找模式中加入\c表示大小写不敏感查找,\C表示大小写敏感查找,例如:/foo\c将会查找所有的"foo","FOO","Foo"等字符串)
:s

(substitute)命令用来查找和替换字符串,语法::{作用范围}s/{目标}/{替换}/{替换标志}; 例如:%s/foo/bar/g会在全局范围(%)查找foo并替换为bar,所有出现都会被替换(g),:s/foo/bar/g 替换当前行,

:%s /foo/bar /g 全局替换

:%d %是匹配所有行,d是删除的意思, 该命令将清空打开的文件的内容
:$ 跳到文件尾部
:n 跳到n行  看到行号 :set number

u 撤销上一步的操作
Ctrl+r 恢复上一步被撤销的操作(返回

四、客户端连接服务器方式

 4.1、SSH


SSH是一种安全协议,主要用于给远程登录会话数据进行加密,保证数据传输的安全

2)SSH服务端和客户端
SSH服务端是一个守护进程,一遍为sshd进程,在后端运行并响应来自客户端的请求。
SSH客户端常用的有BvSsh,SecureCRT,putty等。

3)基本工作机制

  • 客户端发送一个请求到服务端
  • 服务端做数据验证,如包及ip地址等,在发送一个秘钥给ssh客户端
  • 客户端再将密钥发回服务端,自此建立连接

4.2、登录方式两个:

①密码和用户名登录
②密钥登录

ssh-keygen -t rsa

1) 首先在服务器中创建密钥对

[root@localhost .ssh]# ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): 
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:+LTzDddLCyrFVb9bHRMnOssHgOGJbffji/NV5/hPAEA root@localhost.localdomain
The key's randomart image is:
+---[RSA 2048]----+
|        .+E      |
|       +....  o..|
|      . = ...o oo|
|       o . .=. o.|
|      . S. oo+. B|
|       o .o.oo.*+|
|        +.. +.= =|
|        .o.* = * |
|         .+o+ o +|
+----[SHA256]-----+

在创建的过程中会提示输入密码,在次不用输入,直接回车即可,创建的密钥对默认放当前登录用户的家目录下的.ssh目录中。

2)在服务器中安装公钥

[root@localhost .ssh]# cat id_rsa.pub >> authorized_keys
[root@localhost .ssh]# ls
authorized_keys  id_rsa  id_rsa.pub

注:此处特别要注意文件名称不能错误(包括大小写),存放公钥的文件名为: authorized_keys。多个用户多需要登录linux,每个用户都需要密钥,则可以只用上面的追加命令直接将多个用户的公钥直接追加进去即可。

3) 设置文件权限----把私钥给了

[root@localhost .ssh]# chmod 600 authorized_keys
[root@localhost .ssh]# chmod 700 ~/.ssh
  1. 设置ssh的配置文件
[root@localhost .ssh]# vim /etc/ssh/sshd_config

修改如下的配置:

# 加密算法
RSAAuthentication yes

# 使用密钥进行认证
PubkeyAuthentication yes

5)重启ssh服务

[root@localhost .ssh]# systemctl restart sshd
  1. 拷贝私钥到PC端(注意:是私钥 id_rsa),使用软件导入秘钥,然后测试登录

xshell配置如下:

xshell配置如下:

bitvise配置:


点击出现如下图:


原文地址:https://blog.csdn.net/m0_74276368/article/details/135770229

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


linux常用进程通信方式包括管道(pipe)、有名管道(FIFO)、信号(signal)、消息队列、共享内存、信号量、套接字(socket)。管道用于具有亲缘关系的进程间通信,有名管道的每个管道具有名字,使没有亲缘关系的进程间也可以通信。信号是比较复杂的通信方式,用于通知接受进程有某种事件发生,除
Linux性能观测工具按类别可分为系统级别和进程级别,系统级别对整个系统的性能做统计,而进程级别则具体到进程,为每个进程维护统计信息。

按实现原理分,可分为基于计数器和跟踪以及剖析。含义如下:

计数器:内核维护的统计数据,通常为无符号整型,用于对发生的事件计数,比如,网络包接收计数器,磁
本文详细介绍了curl命令基础和高级用法,包括跳过https的证书验证,详细追踪整个交互过程,可用于调用网络后端接口,诊断http和https网络服务故障。
本文包含作者工作中常用到的一些命令,用于诊断网络、磁盘占满、fd泄漏等问题。命令包括ping、fping、tcpdump、lsof、netstat、/proc/$pid/fd、du、grep、traceroute、dig。
linux的平均负载表示运行态和就绪态及不可中断状态(正在io)的进程数目,用uptime查看到负载很高,既有可能是CPU利用率高,也可能是大量在等待io的进程导致,用mpstat查看每个CPU的使用情况,查看CPU的使用率或者CPU花在等待io的时间,接着用pidstat定位具体的进程
CPU上下文频繁切换会导致系统性能下降,切换分为进程切换、线程切换及中断切换,进程切换的开销较大,除了需要保存寄存器和程序计数器中的值还需保存全局变量、栈等到内存中,以便下次运行恢复,而同一进程中的线程切换开销会小很多,只需更新寄存器和线程独有的栈,共享资源如打开的文件、全局变量等无需切换,当硬件中
1.top命令 作用:该命令可以按CPU使用.内存使用和执行时间对任务进行排序,常用来监控系统中占用CPU或内存较高的程序及CPU和内存的负载。 默认视图: 当想看系统负载时,可观察汇总的%CPU中的us用户进程和sy系统进程是否占用CPU很高,相加接近100%就说明占用很高了,有些程序可能得不到及
文章浏览阅读1.8k次,点赞63次,收藏54次。Linux下的目录权限!!!粘滞位!!!超详解!!!
文章浏览阅读1.6k次,点赞44次,收藏38次。关于Qt的安装、Windows、Linux、MacBook_mack book 安装qt
本文介绍了使用shell脚本编写一个 Hello
文章浏览阅读1.5k次,点赞37次,收藏43次。【Linux】初识Linux——了解操作系统的发展历史以及初次体验Linux编程环境
文章浏览阅读3k次,点赞34次,收藏156次。Linux超详细笔记,个人学习时很认真的记录的,觉得好的麻烦点个赞。
文章浏览阅读6.8k次,点赞109次,收藏114次。【Linux】 OpenSSH_9.3p1 升级到 OpenSSH_9.5p1(亲测无问题,建议收藏)_openssh_9.5p1
文章浏览阅读3.5k次,点赞93次,收藏78次。初识Linux中的线程,理解线程的各种概念,理解进程地址空间中的页表转换,介绍pthread线程库并理解线程库!
文章浏览阅读863次。出现此问题为Linux文件权限问题,解决方案为回到引擎目录执行命令。输入用户密码后运行./UnrealEditor。_increasing per-process limit of core file size to infinity.
文章浏览阅读2.9k次。使用文本编辑器:打开CSV文件,并使用文本编辑器(如Notepad++、Sublime Text、Visual Studio Code等)来查看文件的字符编码格式。通常在编辑器的底部状态栏或设置中可以找到当前编码的显示。请注意,上述方法并非绝对准确,特别是当文件没有明确的编码标识时。因此,如果你发现CSV文件在不同的工具或方法中显示不同的编码格式,可能需要进行进一步的分析和判断,或者尝试使用不同的编码转换方法。该命令将输出文件的MIME类型和编码信息。使用命令行工具:在命令行中,你可以使用。_shell读取csv文件逐行处理
本文介绍了如何在Linux系统中升级gcc版本,以便更好地支持C++11及以上版本的新特性。通过升级gcc,可以提升编译器的功能和性能,获得更好的开发体验。详细的步骤和方法请参考原文链接。
文章浏览阅读4.4k次,点赞6次,收藏19次。Mosquitto是一个开源的MQTT消息代理服务器。MQTT是一个轻量级的、基于发布/订阅模式的消息传输协议。 mosquitto的安装使用比较简单,可以方便的来进行一些测试。_linux mosquitto
文章浏览阅读7.2k次,点赞2次,收藏12次。Linux中,用于根目录下有一个.ssh目录,保存了ssh相关的key和一些记录文件。_~/.ssh/
文章浏览阅读4.5k次,点赞5次,收藏18次。首先需要安装 snmp ,使用下面的命令进行安装安装完毕之后,使用下面的命令查看是否安装成功当命令行显示如图即为安装成功。_snmp工具