如果你有多个LINUX系统,用户又想一样,那肿么办呢,就用迁移吧,其实是相当于复制!
1. 先来说下批量用户创建
vi users.sh #创建并编辑user.sh文件,扩展名无所谓
for n in $(seq 1 10)
do
kevin=kevin$n
useradd=$kevin
echo 666666 | passwd –stdin $kevin
done
然后就可以执行这个文件了。这个文件我们在创建在root的家目录/root下[root@RHEL ~]后面的~是root的家目录的意思,所以如果你在当前目录下执行users.sh的话,可以./users.sh或/root/users.sh,如果在别的目录下执行它,就要用后一种方法!
下图是执行的过程,
看下/etc/passwd里是不是已经添加了用户
cat /etc/passwd
成功添加
如果要批量删除就把批处理里的useradd改成userdel,再加上rm –rf /home/$kevin就可以连同家目录一起删除了!如果还要删除组的话,可以加上groupdel=组名
for n in $(seq 1 10)
do
kevin=kevin$n
userdel=$kevin
rm –rf /home/$kevin
done
这样创建后的用户是默认可以登陆系统的,如果只想创建用与FTP的用户可以把后面的/bin/bash改成/sbin/nologin
下面就再说另一种手写的方法:
可以直接vi一个文件,也可以先touch来创建一个文件再vi
存放用户的文件user.txt
kevin1:x:511:511::/home/kevin1:/bin/bash
kevin2:x:512:512::/home/kevin2:/bin/bash
kevin3:x:513:513::/home/kevin3:/bin/bash
以此类推
这个格式与/etc/passwd里的格式是一样的,
用户名:x:UID:GID:用户全称:用户家目录:所用SHELL
可以通过chsh 来查看主机上所有SHELL
Chsh --list
再来一个密码文件password.txt,这个文件内容里的用户名要与users.txt里的用户名相同
kevin1:666666
kevin2:666666
然后通过两个命令来完成:newusers users.txt----添加用户
Chpasswd 如果在/etc/passwd里看到密码是明文的,而不是以x代表的,那可以用命令pwconv来加密密码并把/etc/passwd映射到/etc/shadow里 2.下面就开始说迁移 我们要用到scp这个命令,先来个引用,把scp详细介绍下 scp是 secure copy的缩写, scp是linux系统下基于ssh登陆进行安全的远程文件拷贝命令。linux的scp命令可以在linux服务器之间复制文件和目录. scp命令的用处: scp在网络上不同的主机之间复制文件,它使用ssh安全协议传输数据,具有和ssh一样的验证机制,从而安全的远程拷贝文件。 scp命令基本格式: scp [-1246BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file] [-l limit] [-o ssh_option] [-P port] [-S program] [[user@]host1:]file1 [...] [[user@]host2:]file2 scp命令的参数说明: -1 强制scp命令使用协议ssh1 -2 强制scp命令使用协议ssh2 -4 强制scp命令只使用IPv4寻址 -6 强制scp命令只使用IPv6寻址 -B 使用批处理模式(传输过程中不询问传输口令或短语) -C 允许压缩。(将-C标志传递给ssh,从而打开压缩功能) -p 保留原文件的修改时间,访问时间和访问权限。 -q 不显示传输进度条。 -r 递归复制整个目录。 -v 详细方式显示输出。scp和ssh(1)会显示出整个过程的调试信息。这些信息用于调试连接,验证和配置问题。 -c cipher 以cipher将数据传输进行加密,这个选项将直接传递给ssh。 -F ssh_config 指定一个替代的ssh配置文件,此参数直接传递给ssh。 -i identity_file 从指定文件中读取传输时使用的密钥文件,此参数直接传递给ssh。 -l limit 限定用户所能使用的带宽,以Kbit/s为单位。 -o ssh_option 如果习惯于使用ssh_config(5)中的参数传递方式, -P port 注意是大写的P, port是指定数据传输用到的端口号 -S program 指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。 scp命令的实际应用 1>从本地服务器复制到远程服务器 (1) 复制文件: 命令格式: scp local_file remote_username@remote_ip:remote_folder 或者 scp local_file remote_username@remote_ip:remote_file 或者 scp local_file remote_ip:remote_folder 或者 scp local_file remote_ip:remote_file 第1,2个指定了用户名,命令执行后需要输入用户密码,第1个仅指定了远程的目录,文件名字不变,第2个指定了文件名 第3,4个没有指定用户名,命令执行后需要输入用户名和密码,第3个仅指定了远程的目录,文件名字不变,第4个指定了文件名 实例: scp /home/linux/soft/scp.zip root@www.mydomain.com:/home/linux/others/soft scp /home/linux/soft/scp.zip root@www.mydomain.com:/home/linux/others/soft/scp2.zip scp /home/linux/soft/scp.zip www.mydomain.com:/home/linux/others/soft scp /home/linux/soft/scp.zip www.mydomain.com:/home/linux/others/soft/scp2.zip (2) 复制目录: 命令格式: scp -r local_folder remote_username@remote_ip:remote_folder 或者 scp -r local_folder remote_ip:remote_folder 第1个指定了用户名,命令执行后需要输入用户密码; 第2个没有指定用户名,命令执行后需要输入用户名和密码; 例子: scp -r /home/linux/soft/ root@www.mydomain.com:/home/linux/others/ scp -r /home/linux/soft/ www.mydomain.com:/home/linux/others/ 上面 命令 将 本地 soft 目录 复制 到 远程 others 目录下,即复制后远程服务器上会有/home/linux/others/soft/ 目录 2>从远程服务器复制到本地服务器 从远程复制到本地的scp命令与上面的命令雷同,只要将从本地复制到远程的命令后面2个参数互换顺序就行了。 例如: scp root@www.mydomain.com:/home/linux/soft/scp.zip /home/linux/others/scp.zip scp www.mydomain.com:/home/linux/soft/ -r /home/linux/others/ linux系统下scp命令中很多参数都和 ssh1 有关 , 还需要看到更原汁原味的参数信息,可以运行man scp 看到更细致的英文说明. http://www.cnblogs.com/xuxm2007/archive/2010/08/04/1792179.html scp的目录在/usr/bin下,ok,知道scp怎么用了就好说了 我的另一台linux的ip是10.0.0.2 scp(或/usr/bin/scp)/etc/passwd /etc/shadow /etc/group /etc/gshadow root@10.0.0.2:/etc 把这四个文件复制到10.0.0.2的/etc目录下,如果连同文件一起的话,就还有/home/下的用户家目录,当然这是在目标系统没有用户的情况下,不然目标系统下的用户会丢失的! 如果不想之前的用户丢失,可以在复制之前先对目标电脑上的用户作备份,然后完了再newusers上passwd就可以了,其它的就复制到新的文件里就行了! 下面这个是提示我10.0.0.2这个IP怎么就不能用了,我也看不懂 就换成10.0.0.6了 全100%,OK,复制完成! 现在转到目标机10.0.0.6上 虽说复制完了吧,但还不能用 先来个newusers /etc/passwd,新建下我们复制过来的用户,看可以登陆了,但感觉怪怪的对吧,继续 cp /etc/skel/.* . /home/kevin1------以.开头的是隐藏文件 依次cp到各个用户的家目录下—我知道这不是一个好办法,所以再用一下批处理吧 vi for.txt for n in $(seq 1 10) do cp /etc/skel/.* . /home/Kevin$n/ done OK!