Linux for python教程02
目录
- 1. Linux用户及权限管理
- 2.用户组
- 3. 修改文件权限: chmod
- 3. 编辑器
- 4. Linux常用服务器构建-ftp服务器
- 5.Linux常用服务器搭建-ssh和scp
- 6. vim编辑器
1. Linux用户及权限管理
1.1. who
查看当前谁登录了我
who - q: 一共有多少个人登录了我
- 先ping通电脑:
ping IP address
- 远程登录电脑:
ssh haoch@IP address
- 查看谁登录了我的电脑:
who
1.2. 查看当前用户: whoami
查看当前系统当前账号的用户名
1.3. 添加用户账号: useradd
useradd [参数] 新建用户账号
| 参数 | 含义 |
|---|---|
| -d | 指定用户登录系统的主目录 |
| -m | 自动创建目录 |
| -g | 指定组的名称 |
useradd -d /home/abc abc -m |
创建abc用户,如果/home/abc目录不存在,就自动创建这个目录 |
useradd -d /home/abc abc -g test -m |
创建abc用户,如果/home/abc目录不存在,就自动创建这个目录,同时用户属于abc组 |
cat /etc/passwd |
这个文件下就可以看到注册的用户名 |
注意: 每个用户都要有一个主目录,主目录就是第一次登录系统,用户的默认当前目录(/home/用户);
- 查看现有电脑的用户:
cd /home/ + ls或者ls /home/ - 切换到管理员:
sudo -s - 管理员新建用户:
useradd laowang -m
- 管理员修改用户名的密码:
passwd laowang
- 从管理员退回普通用户:
exit
- 从普通用户到另外一个普通用户:
su - laowang
- 自己改自己的秘密:
passwd
- 删除用户:
userdel -r laowang
1.4 切换用户 su
su - laowang: 切换账户及路径名su laowang:只切换账户,不切换到其目录
sudo -s:切换到管理员
2.用户组
- 查看有哪些用户组:
cat /etc/group或者groupmod+两次Tab - 添加组:
groupadd abc
- 删除组:
groupdel abc
- 查看当前用户所在的用户组:
groups laowang
- 查看用户组的当下存在的用户:
cat /etc/group | grep 'sudo'
- 修改用户所在的组:
- 新建三个组:
groupadd AAA BBB CCC
- 新建一个用户:
useradd lili -m在lili自己的组里面
- 切换到AAA组:
usermod -a -G AAA lili
- 新建三个组:
- 将普通用户拥有切换到管理员权限的能力:
- 添加到adm和sudo用户组:
usermod -a -G adm laowang+usermod -a -G sudo laowang
- 添加到adm和sudo用户组:
3. 修改文件权限: chmod
chmod修改文件权限有两种格式:字母法和数字法
字母法: chmod u/g/o/a +/-/= rwx 文件
| 参数 | 含义 |
|---|---|
| u | user表示该文件的所有者 |
| g | group表示与该文件的所有者属于同一组者,即用户组 |
| o | other表示其他以外的人 |
| a | all表示这三个都是 |
| + | 增加权限 |
| - | 撤销权限 |
| = | 设定权限 |
- 添加拥有者的执行权限:
chmod u+x 123.py
- 添加其他人可以写的权限:
chmod o+w 123.py
- 直接设置权限:
chomod g=w 123.py
- 同时设置几个权限:
chmod u=x, g=x, o=x 1.py
- 删除全部权限:
chmod u=, g=, o= 1.py
数字法: rwx这些权限也可以用数字代替
| 参数 | 数字代号 |
|---|---|
| r | 4 |
| w | 2 |
| x | 1 |
| - | 0(无权限) |
- 快速添加权限:
chmod 761 1.py(7=4+2+1, 6=4+2, 1=1)
(1). 修改文件所有者 chown
chown laowang 1.py
(2). 修改文件所属组: chgrp
chgrp AAA 1.py
3. 编辑器
3.1. gedit编辑器
类似window的记事本和word文档
3.2. sublime编辑器
| 快捷键 | 数字代号 |
|---|---|
| Ctrl+Shift+D | 快速复制 |
| Ctrl + | 字体变大 |
| Ctrl + F | 选中替换代码 |
| Ctrl + L | 选中一行 |
3.3. 安装软件
| 快捷键 | 数字代号 |
|---|---|
sudo apt-get update |
更新源 |
sudo apt-get install softwarename |
安装包 |
sudo apt-cache search softwarename |
搜索软件包 |
sudo apt-cache show softwarename |
获取包的相关信息 |
sudo apt-get remove package |
删除包 |
sudo apt-get remove package --purge |
删除包,以及配置文件等 |
sudo apt-get dist -upgrade |
升级系统 |
sudo apt-get source package |
下载该包的源代码 |
sudo apt-get clean && sudo apt -get autoclean |
清理无用的包 |
- 查看更新:
sudo apt -get update
- 下载安装软件:
sudo apt -get install softwarename
- 删除包: sudo apt -get remove package
4. Linux常用服务器构建-ftp服务器
FTP: 文件传输协议
- 安装vsftpd服务器
sudo apt-get install vsftpd
- 配置vsftpd.conf文件
用于谁可以登录我的电脑啊,指定上传路径啊,允许本机登录啊, 允许哪一个用户可以登录,允许上传文件到FTP服务器啊
sudo vi /etc/vsftpd.conf
- 打开配置文件:
sudo vi /etc/vsftpd.conf- 不允许匿名登录:
anonymous_enable = NO - 指定上传的路径:
local_root = /home/laowang/ftp - 允许本地登录:
local_enabled = YES
- 允许
vsftpd.chroot_list文件中的用户登录FTP服务器:chroot_list_enable = YES + CHROOT_LIST_FILE = /ETC/VSFPD.CHROOT_LIST
- 允许上传文件到FTP服务器:
write_enable = YES
- 不允许匿名登录:
- 建立list文件,将一个用户名放进去:
sudo vi /etc/vsftpd.chroot_list
- 添加一个新的用户名进去
- 将文件夹的拥有者权限减去w权限
- 在ftp文件夹中新建一个文件夹,这个文件夹就是使用ftp客户端进行下载,上传时的文件夹
重启FTP服务器:
sudo /etc/init.d/vsftpd restart- 上传命令:
put somefile
下载命令:
get somefile
- 图形化的FTP服务器软件
FileZilla-window
5.Linux常用服务器搭建-ssh和scp
SSH
SSH是建立在应用层和传输层基础上的安全协议
SSH是目前较为可靠,专门为远程登录回话和其他网络服务提供安全性的协议,常常用于远程登录,以及用户之间的资料拷贝
使用SSH服务,需要安装相应的服务器和客户端,服务器和客户端的关系:如果,A机器想要被B机器远程控制,那么A机器需要安装SSH服务器,B机器需要安装SSH客户端
(1). 安装SSH
A.安装SSH服务器
sudo apt-get install openssh-server
B.远程登录
ssh 用户名@IP
(2). 使用SSH链接服务器
先查看ip地址:
ifconfig
在直接远程登录
ssh 用户名@IP
SCP: linux之间互相拷贝
# 上传文件(本地->远程)
scp Filename RemoteUserName@RemoteHostIP:Remotepath
# 上传文件夹
scp -r Foldername RemoteUserName@RemoteHostIP:RemoteFile
# 下载文件(远程->本地)
scp RemoteUserName@RemoteHostIP:Remotepath Filename
# 下载文件夹
scp -r RemoteUserName@RemoteHostIP:RemoteFile Foldername
6. vim编辑器
vi 123.py
- 打开vi以后,默认进入到一种状态->命令模式
- 输入小写i, 由命令模式转为->编辑模式,在这种模式下才可以编辑
- 按ESC键,输入
:wq, 编辑模式->末行模式,保存并自动退出
| 快捷键 | 含义 |
|---|---|
| 88G | 快速定位到第88行 |
| 1G | 快速定位到文件首行 |
| G | 快速定位到文件末尾行 |
| dd | 删除光标所在行 |
| 5dd | 从当前光标算,删除5行 |
| x | 删除光标前的一个字符 |
| X | 删除光标后的一个字符 |
| D | 删除光标后本行所有内容 |
| d0 | 删除光标前本行所有内容 |
| dw | 删除光标开始位置的字 |
| u | 撤销命令 |
| Ctrl +r | 反撤销 |
| yy | 复制当前行 |
| 19yy | 复制19行 |
| p | 粘贴 |
| 2dd + p | 剪切2行 |
| v | 整体选中,可以选中多行 |
| v +>>/<< | 实现整体移动 |
| r | 替换 |
| :%s/main/MAIN/g | 整个文本将main替换为MAIN |
| :5,15s/main/MAIN/g | 文本第5-15行将main替换为MAIN |
| 查找print(n查看下一个) |
更多精彩

