linux基础了解的学习记录
一、文件结构图
linux的储存结构为文件树
二、绝对路径、相对路径、权限
1、绝对路径:
/usr/local/include 在路径的最前面是 / 开头的
使用环境:当在当前路径下想到其他路径显得文件,需使用绝对路径。
2、相对路径:
local/include 在路径的最前面没有 / 开头的
使用环境:当在当前路径下想进入当前路径下的文件时,可使用相对路径。
3、权限:
文件有执行的权限
drwx rw- rw- d表示是文件而不是文件夹(文件夹d的位置是-),r表示有读的权限,w表示有写的权限,x表示有执行的权限(-表示没有给位置的权限)
三、linux命令、通配符(类似正则表达式)
linux命令:
touch hello.txt 创建一个空的文件
mkdir /home/python/djcode 创建一个空的文件夹路径
tab键 自动补全,当输入的命令太长时,输入几个字符就可以按tab键系统自动补全其他字符
更多常用见:http://www.cnblogs.com/Guido-admirers/p/6210267.html
常用文本编辑器VIM:http://www.cnblogs.com/Guido-admirers/p/6201370.html
通配符(ls过滤):
* 表示匹配一个或多个字符
? 表示匹配一个字符
[abc] 表示匹配[]内的任意一个字符内容
[a-c] 表示匹配[]内的任意一个字符内容
\ 转义符,后面的内容没有通配符含义
重定向:
> 重新定向输出的位置,有文件就清空原文件,没有文件就创建新的文件,把内容输出到指定的文件
>> 重新定向输出的位置,追加文件内容,其他同上
cat:
输出文件所有内容到屏幕,直接显示到结尾(适合小文件的查看)
cat 123.py 345.py > 101.py(合并123和345重定向到101文件)
more:
输出文件所有内容到屏幕,从开头开始显示,分屏显示(适合大文件的查看)
管道(|):
前方的命令的输出作为后面的命令的输入
cd ~:
进入当前用户的家目录
cd -:
快速回到上一次的工作路径
rm:
rm 删除文件
rmdir 删除文件夹,但是不能删除空的文件夹
rm -r 递归的删除目录下的所有内容
rm -f 强制删除,忽略不存在的文件,无需提示
rm -i 以进行交互式方式执行
ln:
创建软链接
ln -s 源文件 链接文件
源文件被删后,通过软连接无法找到文件内容
创建硬链接
ln 源文件 链接文件
相当于给原文件增加文件名,通过rm删除的时候系统会检测该文件有几个文件名,然后删除其中的一个文件名,而非删除文件内容。
grep:
' ' 号内的内容为正则表达式,在文件中按内容查找
grep -n 'a' 111.py(在111文件内寻找'a', -n显示搜索得到行号)
grep -n '^a' 111.py(在111文件内寻找'a'开头的一行)
grep -n 'a$' 111.py(在111文件内寻找'a'结尾的的一行)
grep -n '[Hh]ello' 111.py(在111文件内寻找'hello'或'Hello')
find:
查找文件(文件名可用正则表达式进行匹配)
find ./ -name text.sh(./表示在当前路径下查找)
find /home/ -name '*.sh'(在home路径下找.sh为结尾的文件名)
find /home/ -size +2M(在home路径下找文件大小大于2M的文件,-2M为小于)
find /home -size +3K -size -5M(查找home下文件大小在3K到5M之间的文件)
find /home -perm 0777(查找当前目录下权限为777的文件或目录)
cp:
拷贝(tree显示文件树)
cp 123.py /home/name/pycode -arf(拷贝123到pycode文件夹,'a'全部内容包括链接文件属性等等,'r'递归的执行下面的所有文件,'f'不进行提醒确认。)
mv:
剪切、移动文件、重命名
tar:
归档管理
1| -c 生成档案文件,创建打包文件 2| -v 列出归档解档的详细过程,显示进度 3| -f 指定归档文件名称,f后面一定是.tar文件,所以必须放选项最后 4| -t 列出档案中包含的文件 5| -x 解开档案文件
除了f 要放在最后其他无顺序。
打包命令:tar -cvf text.tar t1.py t2.py t3.py(选项加z,表示打包压缩)
解包命令:tar -xvf text.tar -C /home/name/pycode(-C指定解压文件路径,选项加z,表示解压解包)
gzip:
压缩打包文件:gzip -r text.tar text.tar.gz或者gzip text.tar
解压压缩文件:gzip -d text.tar.gz
bzip2:
文件格式为text.tar.bz2
用法同前,区别zxvf—>jxvf, zcvf—>jcvf
zip与unzip:
跨平台的文件格式
压缩文件:zip myzip 目标文件(没有扩展名)源文件
解压文件:unzip -d text myzip.zip (解压后目录文件 压缩文件)
which:
查看命令位置
常用的的系统管理命令:
cal:
查看系统当前的日历
date:
显示当前时间
修改时间:date 010203042016.55 (date [MMDDhhmm[[CC]YY][.ss]]+ format)
显示格式:date "+%y,%m,%d,%H,%M,%S"
ps:
查看进程信息
ps -aux
1| -a 显示终端上的所有进程 2| -u 显示进程的详细状态 3| -x 显示没有控制终端的进程 4| -w 显示加宽,以便显示更多信息 5| -r 只显示正在运行的进程
reboot\shutdown:
重启、关机
kill -9:
杀死进程
ctrl+shift+t再开一个终端
top:
显示当前资源利用率的动态显示,在top命令执行后,可以按下案件得到对显示的结果进行排序:
M 根据内存使用量来排序 P 根据cpu占有率来排序 T 根据进程运行时间的长短来排序 U 可以根据后面输入的用户名来筛选进程 K 可以根据后面输入的PID来杀死进程 q 退出 h 获得帮助
df:
检测磁盘空间
df -lh
du:
检测当前目录所占磁盘空间
1| -a 递归显示指定目录中各文件和子目录中文件占用的数据块 2| -s 显示指定文件或目录占用的数据块 3| -b 以字节为单位显示磁盘占用情况 4| -l 计算所有文件大小,对硬链接文件计算多次
ifconfig:
查看网卡信息
ping:
测试远程主机连通性
用户和权限相关的命令:
who:
查看当前所有登陆系统的用户信息。
ctrl+alt+F2(F2—F6)转变黑屏显示,F1为图形界面(centos7)
who -q (显示有几个用户登录)
whoami (查看当前登录用户)
ssh:
远程登陆电脑命令,ping通之后可执行下方命令
ssh 用户名@IP地址
(windows使用xshell来进行远程连接)
useradd:
添加用户
useradd guido -m (自动创建用户的家目录)
useradd guido -d /home/name (指定用户家目录)
passwd guido (修改该用户的密码)
su guido (切换用户)
userdel guido:
删除用户
再切换多用户后,想删除用户,需要关闭用户,才可以删除。每次su一次,是保留原用户登录登陆其他用户,exit会返回上一次的用户登录关闭本次登陆。
用户切换登录、删除权限示意图:
用户组管理:
查看有哪些用户组
1、cat /etc/group (cat /etc/passwd 查看用户)
2、groupmod +三次tab键 (ubuntu中有效,centos中无效,其他未验证)
添加、删除组
groupadd (添加)
groupdel(删除)
查看用户在那些用户组
groups 用户名
修改用户所在组
usermod -g 用户组 用户名 (修改用户默认组)
usermod -a -G 用户组 用户名 (添加用户名到用户组)
为创建的普通用户添加sudo权限
usermod -a -G adm usermod -a -G sudo
文件的权限修改:
chmod
字母法:
chmod u+x d.py(添加权限)
chmod o-r d.py(删除权限)
chmod g=w d.py (赋予权限)
chmod a=x d.py (a代表全部)
数字法:
r 4
w 2
x 1
chmod u=1,g=2,o=4 d.py
chmod u=7 d.py
chmod 761 (拥有者、同组成员、其他)
修改文件的所有者
chown 用户名 文件或目录名
修改文件所属组
chgrp 用户组名 文件或目录名
linux常用服务器构建-ftp服务器
FTP是File Transfer Protocol (文件传输协议)的英文简称,而中文简称为“文传协议”。
用于Internet上的控制文件的双向传输。
同时,它也是一个应用程序(Application)。基于不同的操作系统有不同的FTP应用程序,而所有这些应用程序都遵守同一种协议以传输文件。
在FTP的使用当中,用户经常遇到两个概念:“下载”(Download)和“上传”(Upload)。
“下载”文件就是从远程主机拷贝文件至自己的计算机上;
“上传”文件就是将文件从自己的计算机中拷贝至远程主机上。用Internet语言来说,用户可通过客户机程序向(从)远程主机上传(下载)文件。
FTP服务器的下载安装与配置
下载安装 sudo yum install vsftpd 配置vsftpd.conf文件 sudo vim /etc/vsftpd.conf #打开vsftpd.conf 修改内容 anonymous_enable=No #不允许匿名用户登录 local_root=/home/python/ftp #指定ftp上传下载目录 local_enable=YES #允许本机登陆 chroot_list_enable=YES chroot_list_file=/etc/vsftpd.chroot_list #允许该文件中的用户名进行登录FTP服务器 write_enable=YES #允许上传文件到FTP服务器 建立以下文件,并将一个用户名放到此文件中 sudo vim /etc/vsftpd.chroot_list 将此ftp文件夹的拥有者的权限减去w,即文件夹的拥有者不能有写的权限 在文件夹中建立一个文件夹share,此文件夹就是使用ftp客户端进行下载、上传时的文件夹 重启FTP服务器,因为已经修改过/etc/vsftpd.conf,所以只有重启,才能使ftp服务器按照配置进行工作 sudo /etc/init.d/vsftpd restart 测试上传功能,登录ftp服务器 ftp IP 上传put 下载get
linux常用服务器构建-ssh和scp
1.ssh
介绍:
SSH为Secure Shell的缩写,由IETF的网络工作小组(Network Working Group)所制定;SSH为建立在应用层和传输层基础上的安全协议。
SSH是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。常用于远程登录,以及用户之间进行资料拷贝。
利用SSH协议可以有效防止远程管理过程中的信息泄露问题。SSH最初是UNIX系统上的一个程序,后来又迅速扩展到其他操作平台。SSH在正确使用时可以弥补网络中的漏洞。SSH客户端适用于多种平台。
使用SSH服务,需要安装相应的服务器和客户端。客户端和服务器的关系:如果,A机器想B机器远程控制,那么,A机器需要安装SSH服务器,B机器需要安装SSH客户端。
安装:
sudo yum install openssh-server(安装)
ssh 用户名@IP (登录)
2、scp
远程拷贝文件,scp -r的常用方法:
使用格式:
下载
scp -r 目标用户名@目标主机IP地址:/目标文件的绝对路径 /保存到本机的绝对或相对路径
scp 192.168.1.1:/home/python/b.txt ./ (保存文件到当前目录下)
上传
scp -r /保存在本机的绝对或相对路径 目标用户名@目标主机IP地址:/目标文件的绝对路径
scp a.txt 192.168.1.1:/home/python/ (把本地文件上传到服务器的该路径下)