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/   (把本地文件上传到服务器的该路径下)

 

posted @ 2017-01-13 11:21  橡皮头  阅读(211)  评论(0编辑  收藏  举报