linux网络通信(linux常用软件官网)

求linux socket网络编程代码

Linux是多任务的操作系统,可在运行在Intel 80386及更高档次的PC机、ARMS、MIPS和PowerPC等多种计算机平台,已成为应用广泛、可靠性高、功能强大的计算机操作系统,Linux具有内核小、效率高、源代码开放等优点,还内含了TCP/IP网络协议,很适合在服务器领域使用,而服务器主要用途之一就是进行网络通信,随着计算机办公自动化处理技术的应用与推广,网络的不断普及,传统的纸张式文件传输方式已经不再适合发展的需要,人们更期待一种便捷、高效、环保、安全的网络传输方式.

协议概述TCP/IP即传输控制协议/网络协议[1](Transmission Control Protocol/Internet Protocol),是一个由多种协议组成的协议族,他定义了计算机通过网络互相通信及协议族各层次之间通信的规范,图1描述了Linux对IP协议族的实现机制[2]。

Linux支持BSD的套接字和全部的TCP/IP协议,是通过网络协议将其视为一组相连的软件层来实现的,BSD套接字(BSD Socket)由通用的套接字管理软件支持,该软件是INET套接字层,用来管理基于IP的TCP与UDP端口到端口的互联问题,从协议分层来看,IP是网络层协议,TCP是一个可靠的端口到端口的传输层协议,他是利用IP层进行传接报文的,同时也是面向连接的,通过建立一条虚拟电路在不同的网路间传输报文,保证所传输报文的无丢失性和无重复性。用户数据报文协议(User Datagram Protocol,UDP)也是利用IP层传输报文,但他是一个非面向连接的传输层协议,利用IP层传输报文时,当目的方网际协议层收到IP报文后,必须识别出该报文所使用的上层协议(即传输层协议),因此,在IP报头上中,设有一个"协议"域(Protocol)。通过该域的值,即可判明其上层协议类型,传输层与网络层在功能说的最大区别是前者提供进程通信能力,而后者则不能,在进程通信的意义上,网络通信的最终地址不仅仅是主机地址,还包括可以描述进程的某种标识符,为此,TCP/UDP提出了协议端口(Protocol Port)的概念,用于标识通信的进程,例如,Web服务器进程通常使用端口80,在/etc/services文件中有这些注册了的端口地址。

对于TCP传输,传输节点间先要建立连接,然后通过该连接传输已排好序的报文,以保证传输的正确性,IP层中的代码用于实现网际协议,这些代码将IP头增加到传输数据中,同时也把收到的IP报文正确的传送到TCP层或UDP层。TCP是一个面向连接协议,而UDP则是一个非面向连接协议,当一个UDP报文发送出去后,Linux并不知道也不去关心他是否成功地到达了目的的主机,IP层之下,是支持所有Linux网络应用的网络设备层,例如点到点协议(Point to Point Protocol,PPP)和以太网层。网络设备并非总代表物理设备,其中有一些(例如回送设备)则是纯粹的软件设备,网络设备与标准的Linux设备不同,他们不是通过Mknod命令创建的,必须是底层软件找到并进行了初始化之后,这些设备才被创建并可用。因此只有当启动了正确设置的以太网设备驱动程序的内核后,才会有/dev/eth0文件,ARP协议位于IP层和支持地址解析的协议层之间。

网络通信原理所有的网络通信就其实现技术可以分为两种,线路交换和包交换,计算机网络一般采用包交换,TCP使用了包交换通信技术,计算机网络中所传输的数据,全部都以包(Packet)这个单位来发送,包由"报头"和"报文"组成,结构如图2所示,在"报头"中记载有发送主机地址,接收主机地址及与报文内容相关的信息等,在"报文"中记载有需要发送的数据,网络中的每个主机和路由器中都有一个路由寻址表,根据这个路由表,包就可以通过网络传送到相应的目的主机。

网络通信中的一个非常重要的概念就是套接字(Socket)[3,4],简单地说,套接字就是网络进程的ID,网络通信归根到底是进程的通信,在网络中,每个节点有一个网络地址(即IP地址),两个进程通信时,首先要确定各自所在网络节点的网络地址,但是,网络地址只能确定进程所在的计算机,而一台计算机上可能同时有多个网络进程,还不能确定到底是其中的哪个进程,由此套接字中还要有其他的信息,那就是端口号(Port),在一台计算机中,一个端口一次只能分配给一个进程,即端口号与进程是一一对应的关系,所以,端口号和网络地址就能唯一地确定Internet中的一个网络进程。可以认为:套接字=网络地址+端口号系统调用一个Socket()得到一个套接字描述符,然后就可以通过他进行网络通信了。

套接字有很多种类,最常用的就有两种;流式套接字和数据报套接字。在Linux中分别称之为"SOCK_STREAM"和"SOCK_DGRAM)"他们分别使用不同的协议,流式套接字使用TCP协议,数据报套接字使用UDP协议,本文所使用的是流式套接字协议。

网络通信原理在文件传输程序设计中的应用网络上的绝大多数通信采用的都是客户机/服务器机制(Client/Server),即服务器提供服务,客户是这些服务的使用者,服务器首先创建一个Socket,然后将该Socket与本地地址/端口号绑定(Bind()),成功之后就在相应的Socket上监听(Listen())。当Accept()函数捕捉到一个连接服务(Connect())请求时,接受并生成一个新的Socket,并通过这个新的Socket与客户端通信,客户端同样也要创建一个Socket,将该Socket与本地地址/端口号绑定,还需要指定服务器端的地址与端口号,随后向服务器端发出Connect(),请求被服务器端接受后,可以通过Socket与服务器端通信。

TCP是一种面向连接的、可靠的、双向的通信数据流,说他可靠,是因为他使用3段握手协议传输数据,并且在传输时采用"重传肯定确认"机制保证数据的正确发送:接收端收到的数据后要发出一个肯定确认,而发送端必须要能接受到这个肯定信号,否则就要将数据重发。在此原理基础之上,设计了基于Linux操作系统下TCP/IP编程实现文件传输的实例。我们采用客户机/服务器模式通信时,通信双方发送/接收数据的工作流程如图3所示。

文件传输就是基于客户机/服务器模型而设计的,客户机和服务器之间利用TCP建立连续,因文件传输是一个交互式会话系统,客户机每次执行文件传输,都需要与服务器建立控制连接和数据连接,其中控制连接负责传输控制信息、利用控制命令、客户机可以向服务器提出无限次的请求,客户机每次提出的请求,服务器与客户机建立一个数据连接,进行实际的数据传输,数据传输完毕后,对应的数据连接被清除,控制连接依然保持,等待客户机发出新的传输请求,直到客户机撤销控制连接,结束会话。

当进行文件传输时,首先向服务器发出连接请求,服务器验证身份后,与客户端建立连接,双方进入会话状态,这时只要客户端向服务器端发出数据连接请求,建立起数据连接后,双方就进入数据传输状态,数据传输完毕后,数据连接被撤销,如此循环反复,直到会话结束,从而实现将文件从服务器端传输至客户机端。

文件传输程序设计流程[5,客户端的TCP应用程序流程(1)先用Socket()创建本地套接口,给服务器端套接口地址结构赋值。

(2)用Connect()函数使本地套接口向服务器端套接口发出建立连接请求,经3次握手建立TCP连接。

(3)用Read()函数读取所要接收的文件名以及存放在内存里的文件内容。

(4)用Open()函数打开客户端新建立的目标文件,如果没有建立,该函数会自动生成目标文件,等待存放文件内容。

(5)最后用Write()函数将读取的文件内容存放在新的目标文件中,以实现服务器端向客户端的文件传输。

(6)通信结束,用Close()关闭套接口,停止接收文件。

服务器端的TCP应用程序流程(1)先用Open()函数打开等待传输的可读文件;(2)用Socket()创建套接口,并给套接口地址结构赋值;(3)用Bind()函数绑定套接口;(4)用Listen()函数在该套接口上监听请求;(5)用Accept()函数接受请求,产生新的套接口及描述字,并与客户端连接;(6)用Lseek()函数是为了在每次接受客户机连接时,将用于读的源文件指针移到文件头;(7)用Read()函数读取一定长度的源文件数据;(8)最后用Write()函数将读取的源文件数据存放在内存中,以便客户端读取;(9)传输完毕时,用Close()关闭所有进程,结束文件传输。

结语Linux操作系统在网络应用方面具有很强的开发潜力,同时Linux也是可靠性、安全性非常高的系统,因此在基于TCP/IP网络通信的研究与开发中,通常选用Linux操作系统作为开发平台

Linux中Wi-Fi无线网络和AP无线热点的配置教程

0.Linux下的Wi-Fi配置

无线网络飞速发展的今天,许多设备都提供了连接无线网络的功能。

那么Linux下的wifi到底该怎么配置、连接呢??

开始配置之前,我们要说说iw家族。iw是linux下常用的wifi配置工具,网上有相应的库和源码。全名为wirelessTools。

配置wifi模块,并连接相应的无线网络过程:主要使用iwpriv命令

(1)扫描可用的无线网络:

代码如下:

iwlist wifi-name scanning 

其中wifi-name为无线网卡的名字,比如网卡eth0就是系统默认的网卡名字, wifi-name可以用ifconfig查看,一般为ra0。

(2)看扫描到的网络信息,按要连接的网络类型进行配置。以下为扫描到的网络:

代码如下:

iwlist ra0 scanning 

===rt_ioctl_giwscan. 11(11) BSS returned, data-length= 1427 

ra0      Scan completed: 

 Cell 01- Address: C4:CA:D9:1D:9E:A0 

   Protocol:802.11b/g/n 

   ESSID:"" 

   Mode:Managed 

   Frequency:2.412 GHz(Channel 1) 

   Quality=7/100 Signal level=-87 dBm Noise level=-82 dBm 

   Encryption key:off 

   Bit Rates:54 Mb/s 

 Cell 02- Address: FC:75:16:A1:A9:16 

   Protocol:802.11b/g/n 

   ESSID:"jxj_rd" 

   Mode:Managed 

   Frequency:2.452 GHz(Channel 9) 

   Quality=94/100 Signal level=-53 dBm Noise level=-92 dBm 

   Encryption key:on 

   Bit Rates:54 Mb/s 

   IE: WPA Version 1 

Group Cipher: TKIP 

Pairwise Ciphers(2): TKIP CCMP 

Authentication Suites(1): PSK 

   IE: IEEE 802.11i/WPA2 Version 1 

Group Cipher: TKIP 

Pairwise Ciphers(2): TKIP CCMP 

Authentication Suites(1): PSK 

 Cell 03- Address: C4:CA:D9:02:2A:70 

   Protocol:802.11b/g/n 

   ESSID:"" 

   Mode:Managed 

   Frequency:2.462 GHz(Channel 11) 

   Quality=83/100 Signal level=-57 dBm Noise level=-92 dBm 

   Encryption key:off 

   Bit Rates:54 Mb/s 

 Cell 04- Address: 14:D6:4D:75:CA:9C 

   Protocol:802.11b/g/n 

   ESSID:"liangym" 

   Mode:Managed 

   Frequency:2.472 GHz(Channel 13) 

   Quality=100/100 Signal level=-27 dBm Noise level=-92 dBm 

   Encryption key:on 

   Bit Rates:54 Mb/s 

   IE: WPA Version 1 

Group Cipher: CCMP 

Pairwise Ciphers(1): CCMP 

Authentication Suites(1): PSK 

   IE: IEEE 802.11i/WPA2 Version 1 

Group Cipher: CCMP 

Pairwise Ciphers(1): CCMP 

Authentication Suites(1): PSK 

如上:ESSID项的值即为无线网络的名字,如上的jxj_rd等。如果值为空,说明在无线路由勾选了隐藏ESSID的选项。

ESSID是很关键的,如果被隐藏了,也不是不能连接,而是需要破解,用到其他的工具,非常麻烦。至于如何破解,不是本文叙述的内容,有兴趣的朋友可以网上搜索。

得到了网络的信息,接下来就是配置连接选项了。以连接jxj_rd为例,我们看看具体的过程:

(1)设置要连接的网络类型:

代码如下:

iwpriv ra0 set NetworkType=Infra 

(2)设置要连接的无线网络的安全模式:

代码如下:

iwpriv ra0 set AuthMode=WPA2PSK 

(3)设置网络加密方式:(CCMP即为AES)

代码如下:

iwpriv ra0 set EncrypType=TKIP 

(4)设置连接时的密码:********为加密网络的密码

代码如下:

iwpriv ra0 set WPAPSK=******* 

(5)连接该网络:有两种方式:

A、用iwpriv命令

代码如下:

iwpriv ra0 set SSID=jxj_rd 

B、用iwconfig命令

代码如下:

iwconfig ra0 essid jxj_rd 

至此,如果密码正确,就可以连接上网络jxj_rd了。如果你不放心,可以用命令查看状态:

代码如下:

iwpriv ra0 connStatus

当然,你也可以用iwconfig命令查看状态,这里不再赘述。

执行 iwlist如果 Supported interface modes的下有 AP的话表示该网卡支持AP模式,可以创建无线热点。

比如我的无线网卡是Qualcomm Atheros AR9485 Wireless Network Adapter,Linux内核自带了驱动ath9k,支持创建AP无线热点。

下面我们就着重来讲无线热点的创建步骤:

1.安装hostapd和dhcpd

代码如下:

sudo apt-get install hostapd isc-dhcp-server

开机不需要启动这两个服务,建议把它们关掉:

代码如下:

sudo update-rc.d-f hostapd remove

注释掉下面两个文件start on那一行:

代码如下:

sudo nano/etc/init/isc-dhcp-server.conf

sudo nano/etc/init/isc-dhcp-server6.conf

2.配置hostapd和dhcpd

代码如下:

sudo nano/etc/hostapd/hostapd.conf 

注意自己设置其中的无线热点名称ssid和认证密码wpa_passphrase.

代码如下:

interface=wlan0

driver=nl80211

ssid=YOUR_AP_NAME

hw_mode=g

channel=10

macaddr_acl=0

auth_algs=3

wpa=2

wpa_passphrase=YOUR_AP_PASSWORD

wpa_key_mgmt=WPA-PSK

wpa_pairwise=TKIP CCMP

rsn_pairwise=TKIP CCMP

sudo nano/etc/dhcp/dhcpd.conf

在末尾加入以下内容:

代码如下:

subnet 192.168.0.0 netmask 255.255.255.0

{

range 192.168.0.2 192.168.0.10;

option routers 192.168.0.1;

option domain-name-servers 192.168.0.1,180.76.76.76,8.8.8.8;

}

其中180.76.76.76是百度公共DNS服务器,8.8.8.8则是Google的DNS服务器.

在自己的家目录下创建一个hostapd目录,里面新建启动和关闭脚本,比如我这样写(注意把里面eechen换成你的用户名):

代码如下:

nano /home/eechen/hostapd/ap-start.sh

代码如下:

#!/bin/bash

#开启内核IP转发

bash-c"echo 1/proc/sys/net/ipv4/ip_forward"

#开启防火墙NAT转发(如果本机使用eth0上网,则把ppp0改为eth0)

iptables-t nat-A POSTROUTING-o ppp0-j MASQUERADE

#关闭NetworkManager对无线网卡的控制

nmcli nm wifi off

#设置并启动无线网卡

ifconfig wlan0 192.168.0.1 netmask 255.255.255.0

#解锁无线设备,可以用rfkill list查看解锁结果.

rfkill unblock wlan

#睡眠6秒,待rfkill解锁生效

sleep 6s

#启动dhcpd和hostapd,如果hostapd无法启动请查看日志hostapd.log,查看这两个进程ps-ef|egrep"dhcpd|hostapd"

nohup hostapd/etc/hostapd/hostapd.conf/home/eechen/hostapd/hostapd.log 21

dhcpd wlan0-pf/var/run/dhcpd.pid

ps-ef|head-n1 ps-ef|egrep"dhcpd|hostapd"

nano /home/eechen/hostapd/ap-stop.sh

代码如下:

#!/bin/bash

killall hostapd dhcpd

bash-c"echo 0/proc/sys/net/ipv4/ip_forward"

ifconfig wlan0 down

3.启动hostapd和dhcpd

在桌面新建两个启动器(快捷方式),里面分别填入:

代码如下:

gksu/home/eechen/hostapd/ap-start.sh

gksu/home/eechen/hostapd/ap-stop.sh

因为脚本需要root用户身份执行,所以需要用gksu运行。

注意:如果你开启了ufw防火墙,ufw默认是禁止转发的,这会导致防火墙NAT转发失效,这时应该设置允许转发:

代码如下:

sudo nano/etc/default/ufw将 DEFAULT_FORWARD_POLICY设为 ACCEPT

然后重启ufw即可:

代码如下:

sudo service ufw restart

之后运行启动器即可启动和关闭AP无线热点。

4.用wireshark监控经过wlan0的通信

安装wireshark(其中 eechen改为你的用户名):

代码如下:

sudo apt-get install wireshark

sudo chgrp eechen/usr/bin/dumpcap

sudo chmod 750/usr/bin/dumpcap

sudo setcap cap_net_raw,cap_net_admin+eip/usr/bin/dumpcap

Alt+F2运行wireshark,选择网络接口wlan0,Filter里输入http.cookie contains mail.qq.com

然后手机端登录网页QQ邮箱,在WireShark即可查看和获取QQ邮箱登录的Cookie,如图所示:

右键点击Cookie项把Value复制出来,然后用Firefox访问站点,Alt+C激活 Original Cookie Injector( GreaseMonkey),弹出输入框Wireshark Cookie Dump,把Cookie项的Value粘贴到里面,然后点OK确定并刷新页面即可登录QQ邮箱。或者你使用Tamper Data这个Firefox扩展在提交时修改Cookie值也是可以的。

附:

查看连接wlan0网络的客户端:

代码如下:

sudo arp

返回IP地址和MAC硬件地址和无线接口名.

代码如下:

iw dev wlan0 station dump

能显示收发包和字节数等.

查看网络接口速度:

代码如下:

sar-n DEV 1

1、Linux系统基本网络

1.1、服务器注意事项:

远程服务器不允许关机,只能重启

重启时应该先关闭服务

不要在服务器访问高峰运行高负载命令

远程配置防火墙时不要把自己踢出服务器

指定合理的密码规范并定期更新

合理分配权限

定期备份重要的数据和日志

1.2、设置网络桥接命令和(ANT模式):

systemctl restart network------重启网卡service network restart---------重启网络服务

systemctl  stop NetworkManager临时暂停网络管理器systemctl disable NetworkManager永久关闭网络管理器

systemctl start NetworkManager   拥有root用户的可执行权限

systemctl stop NetworkManager   停止并禁用虚拟机 NetworkManager服务

systemctl disable NetworkManager

注意:修改网络配置文件后,需要重新加载网络连接,如果是通过network.service则使用命令:systemctl restart network;如果是通过NetworkManager.service则使用nmcli命令:nmcli connection reload。

设置网络主要操作(桥接模式和)

[root@localhost network-scripts]# cd etc/sysconfig/network-scripts/

[root@localhost network-scripts]# vi ifcfg-ens33

systemctl restart network------重启网卡

service network restart---------重启网络服务

TYPE=Ethernet

PROXY_METHOD=none

BROWSER_ONLY=no

BOOTPROTO=static      设置静态

DEFROUTE=yes

IPV4_FAILURE_FATAL=yes

IPV6INIT=yes

IPV6_AUTOCONF=yes

IPV6_DEFROUTE=yes

IPV6_FAILURE_FATAL=no

IPV6_ADDR_GEN_MODE=stable-privacy

NAME=ens33

UUID=10c17057-e9c9-4831-a8ff-0757ea0abc0b

DEVICE=ens33

ONBOOT=yes             #开机重启

#IPADDR=192.168.43.168       #ip地址(需要跟主机同一个网段,不同一个IP)

IPADDR=10.63.73.20         

#NETMASK=255.255.255.0       #子网掩码(下面三个都跟主机一样)

NETMASK=255.255.0.0

#GATEWAY=192.168.43.1       #网关

GATEWAK=10.63.255.254

#GATEWAK=10.200.0.3

#DNS1=192.168.43.1         #DNS服务

设置网络主要步骤(Nat模式)

1.打开Vm,点击编辑->虚拟网络编辑

2.选择VMnet8,将VMnet信息改为NAT模式,比如我的本机IP是192.168.138.1,子网掩码为255.255.255.0

所以我将下面的IP配置成192.168.138.0子网掩码配置成255.255.255

3.再点击NAT设置将网管配置成192.168.138.2(ps:网关不要配置成和自己IP地址一样)

然后再应用确定

4.右键点击虚拟机设置,网络适配器改为自定义(选择Vmnet8 Nat模式)

5.接下来开启虚拟机

cd/etc/sysconfig/network-scripts/

vim ifcfg-eno16777736

然后再执行命令:/etc/init.d/network restart

1.3、设置防火墙

1.3.1、防火墙命令

停止防火墙:

systemctl stop firewalld.service#停止firewall防火墙

service  iptables stop #(centos7版本之前)

永久关闭防火墙:

systemctl disable firewalld.service#禁止firewall开机启动(永久关闭防火墙)

chkconfig iptables off#永久关闭防火墙

开始防火墙:

systemctl start firewalld #启动防火墙

systemctl restart iptables.service#重启防火墙使配置生效

systemctl enable iptables.service#设置防火墙开机启动(重启)

查看防火墙状态:

systemctl status firewalld

service  iptables status#(7版本之前)

1.3.2、Linux chkconfig命令

Linux chkconfig命令用于检查,设置系统的各种服务。

这是Red Hat公司遵循GPL规则所开发的程序,它可查询操作系统在每一个执行等级中会执行哪些系统服务,其中包括各类常驻服务。

语法

chkconfig [--add][--del][--list][系统服务]或 chkconfig [--level<等级代号>][系统服务][on/off/reset]

参数:

--add增加所指定的系统服务,让 chkconfig指令得以管理它,并同时在系统启动的叙述文件内增加相关数据。

--del删除所指定的系统服务,不再由 chkconfig指令管理,并同时在系统启动的叙述文件内删除相关数据。

--level<等级代号>指定读系统服务要在哪一个执行等级中开启或关毕。

实例

列出chkconfig所知道的所有命令,可以用chkconfig–list查看所有的服务及其在每个级别的开启状态。

# chkconfig--list

开启服务

# chkconfig telnet on //开启 Telnet服务

# chkconfig--list   //列出 chkconfig所知道的所有的服务的情况

关闭服务

# chkconfig telnet off //关闭 Telnet服务

# chkconfig--list   //列出 chkconfig所知道的所有的服务的情况

[root@cent01 sbin]# chkconfig--level 3 network off //关闭3级别的network服务

[root@cent01 sbin]# chkconfig--list//3级别已关闭

network     0:关 1:关 2:开 3:关 4:开 5:开 6:关

[root@cent01 sbin]# chkconfig network on//不输入级别,默认打开2,3,4,5级别

[root@cent01 sbin]# chkconfig--list

network     0:关 1:关 2:开 3:开 4:开 5:开 6:关

[root@cent01 sbin]# chkconfig--del network//删除network

[root@cent01 sbin]# chkconfig--list //network已消失

mysqld      0:关 1:关 2:开 3:开 4:开 5:开 6:关

netconsole    0:关 1:关 2:关 3:关 4:关 5:关 6:关

[root@cent01 sbin]# chkconfig--add network//增加network服务

[root@cent01 sbin]# chkconfig--list //network服务又恢复了

mysqld      0:关 1:关 2:开 3:开 4:开 5:开 6:关

netconsole    0:关 1:关 2:关 3:关 4:关 5:关 6:关

network     0:关 1:关 2:开 3:开 4:开 5:开 6:关

[root@cent01 sbin]# chkconfig--list

注:该输出结果只显示 SysV服务,并不包含

原生 systemd服务。SysV配置数据

可能被原生 systemd配置覆盖。

   要列出 systemd服务,请执行'systemctl list-unit-files'。

   查看在具体 target启用的服务请执行

   'systemctl list-dependencies [target]'。

mysqld      0:关 1:关 2:开 3:开 4:开 5:开 6:关

netconsole    0:关 1:关 2:关 3:关 4:关 5:关 6:关

注意:但是这里只显示了SysV管理的服务,centos6及之前都是这个管理工具,但是在centos7用的是systemd管理,所以systemd管理的服务在这里没有显示出来。

运行级别为系统启动级别,具体含义如下:

0 shutdown关机

1单用户模式

2无NFS支持的多用户模式

3完全多用户模式,常用的命令行模式

4保留给用户自定义

5图形界面登录,比3多了一个图形界面

6重启

1.3.2、Linux systemd命令

systemd是管理开机启动程序的工具(SysV启动开机进程时一次只能启动一个,而systemd则一次可以启动多个服务,这样就导致systemd的开机速度会更快。)

[root@localhost~]# systemctl list-units--all--type=service

  UNIT               LOAD    ACTIVE  SUB   DESCRIPTION

  abrt-ccpp.service        loaded   active  exited  Install ABRT coredump hook

  abrt-oops.service        loaded   active  running ABRT kernel log watcher

  UNIT               LOAD    ACTIVE  SUB   DESCRIPTION

[root@cent01 sbin]# ls/usr/lib/systemd/system //启动的脚本文件目录

[root@cent01~]# systemctl list-units //列出正在运行的unit

[root@cent01~]# systemctl list-units--all//列出所有的unit,包括active和inactive

[root@cent01~]# systemctl list-units--all--state=inactive//列出inactive的unit

[root@cent01~]# systemctl list-units--all--type=service //列出所有状态的service

[root@cent01~]# systemctl list-units--type=service //列出active的service

[root@cent01~]# systemctl is-active crond.service //查看某个unit是否active

systemctl enable crond.service//开机启动.service可以省略

systemctl disable crond.service//禁止开机启动

systemctl status crond.service //查看服务状态

systemctl start crond.service//启动服务

systemctl stop crond.service //停止服务

systemctl restart crond.service //重启服务

systemctl is-enabled crond.service //查看某个服务是否开机启动

unit/usr/lib/systemd/system此目录下列出了很多文件,这些文件都是unit。类别如下:

service系统服务target多个unit组成的组device硬件设备mount文件系统挂载点automount自动挂载点path文件或路径scope不是由systemd启动的外部进程slice进程组snapshot systemd快照socket进程间通信的套接字swap swap文件timer定时器

target target类似于centos6的启动级别,target内又包含多个unit的组合,当然target内也可以包含target。启动target就是启动多个unit,用target来管理这些unit。

[root@cent01~]# systemctl list-units--all--type=target //查看当前所有的target

  UNIT            LOAD    ACTIVE  SUB   DESCRIPTION

  basic.target        loaded   active  active Basic System

  bluetooth.target      loaded   active  active Bluetooth

[root@localhost~]# systemctl list-dependencies multi-user.target

multi-user.target

●├─abrt-ccpp.service

●├─abrt-oops.service

●├─abrt-vmcore.service

●├─abrt-xorg.service

[root@localhost~]# systemctl get-default //查看系统默认的target

multi-user.target

systemctl set-default multi-user.target //设置默认的target

multi-user.target等同于centos6的运行级别3。他们的对应关系如下:

SysV运行级别systemd target备注

0poweroff.target关闭系统

1rescure.target单用户模式

2multiuser.target用户自定义级别,通常识别为3

3multiuser.target多用户命令行模式

4multiuser.target用户自定义级别,通常识别为3

5graphical.target多用户图形界面,比级别3只多一个GUI

6reboot.target重启

所以总结起来,一个service属于一种unit,多个unit组成一个target,当然target里面也可以包含target。

1.4、ifconfig命令配置IP网络参数

格式:

[root@localhost/]#ifconfig [网络设备] [ip地址] [MAC地址] [netmask掩码地址] [broadcast广播地址(NDC)] [up/down]

[root@localhost/]#ifconfig eth0 192.168.74.130 netmask 255.255.255.0 up

用ifconfig命令配置eth0别名设备,为eth0绑定多个IP地址。

[root@localhost/]#ifconfig eth0:1 192.168.74.130

[root@localhost/]#ifconfig eth0:2 192.168.73.130

1.5、使用routedel命令添加路由

格式:

[root@localhost/]#routedel [-net|host] [网域或主机] netmask [mask] [gw]

[root@localhost/]#route#查看路由信息

功能:添加路由

-net:表示后面接的路由为一个网络。

-host:表示后面接的为连接到单部主机的路由。

netmask:与网络有关,可以设定netmask决定网路的大小。

gw: gateway(网关)的简写,后面接的是ip地址。

1.6、使用hostname命令修改主机名称

[root@localhost/]#hostname service.jw.com

hostnamectl set-hostname nod1

阅读剩余
THE END