1, Configure SMTP mail service according to the following requiremnets:
-- Your mail server should accept mail from remote hosts and localhost
-- harry must be able to receive mail from remote hosts

-- Mail delivered to mary should spool into the default mail spool for mary /var/spool/mail/mary

install the postfix,

yum install -y postfix


start the postfix and make it auto on when booting,

service postfix start
chkconfig postfix on


modify the main.cf

vim /etc/postfix/main.cf

the original inet_interfaces is localhost, if needs to receive the internal and external mails, needs to switch on inet_interfaces = all, and comments off localhost, as following,

inet_interfaces = all
#inet_interfaces = $myhostname
#inet_interfaces = $myhostname, localhost
#inet_interfaces = localhost

harry is local user, so he can receive the external mail, mary should spool into the default mail spool for mary /var/spool/mail/mary, this one also no need to do anything.

Restart the service,

service postfix restart
chkconfig postfix on


check ports is on now,

netstat -ntulp | grep :25


check the hostname,

postconf myhostname


if the hostname is incorrect, needs to modify the /etc/postfix/main.cf, in the line of mydestination add "server3.example.com"

mydestination=.....,server3.example.com

send an email to test the SMTP,

echo "hello mary" | mail -s "subject" mary@server3.example.com
mail -u mary


2, Configure an email alias your MTA such that mail sent to harry is received by the local user mary


modify the /etc/aliase

vim /etc/aliase

add one line as following, and add harry at the end, mail transferred to mary and harry also can receive mail.

harry mary,harry

update the database,

newaliases

test the result,

echo "hello harry" | mail -s "subject" harry@server3.example.com


mail -u mary
mail -u harry
chkconfig postfix on


3, Create a shell script /root/program:


--when you input "kernel" parameter to the shell script that will return "user"


--when you input "user" parameter to the shell script that will return "kernel"


--while script no parameter or parameter is wrong,standard error "usage:/root/program kernel|user"

vim /root/program

add the source code,

#!/bin/bash
if
[ "$1" == "user" ];
then
echo "kernel";
elif
[ "$1" == "kernel" ];
then
echo "user";
else
echo "usage:/root/program kernel|user."
fi


here needs  to pay attention to one thing,  [ "$1" == "user" ], there are some spaces in the middle, if you missed out the space, the shell program will not work. test the result, ./program user will output kernel, ./program kernel, will output user, if ./program, it will output "usage:/root/program kernel|user."


another way to achieve this is by using the case program,

#!/bin/bash
case $1 in
user)
echo "kernel" ;;
kernel)
echo "user" ;;
*) echo 'usage:/root/program kernel|user.'
esac

4, ftp service, allow anonymous to upload file, upload folder path as /var/ftp/upload

lock the local user to home directory, limit certain user to home directory

limit certain user to login to ftp service.

install the vsftp,

yum install vsftp


start the service and make it auto on,

service vsftpd restart
chkconfig vsftpd on


modify the vsftpd.conf,

vim /etc/vsftpd/vsftpd.conf


uncomment following two lines, save and restart the vsftpd service,


anon_upload_enable=YES
anon_mkdir_write_enable=YES

restart the service


service vsftpd restart

create the uploading folder,

mkdir -p /var/ftp/upload


change the access right,

chown ftp.ftp /var/ftp/upload
chmod 775 /var/ftp/upload


change the selinux bool value,

getsebool -a | grep ftp
setsebool -P allow_ftpd-anon_write on
Setsebool -P allow_ftpd_anon_full_access on


test the result,

lftp 192.168.0.103


ls and !ls to display the folder,

put post.log


lock the user to home directory,

vim /etc/vsftpd/vsftpd.conf


switch on chroot_local_user

chroot_local_user=YES


restart the vsftp

service vsftpd restart


test the result,

ftp 192.168.0.103


login as student, and try to go to other folder,

cd /var/ftp


it will return error, "550 failed to change directory"

limit certain user to home directory,

vim /etc/vsftpd/vsftpd.conf


uncomment following two lines,

chroot_list_enable=YES
chroot_list_file=/etc/vsftpd/chroot_list


create file chroot_list,

vim /etc/vsftpd/chroot_list

add sutdent and visitor


limit certain user to login ftp service, modify /etc/vsftpd/ftpusers, to add the users needs to be limited.

vim /etc/vsftpd/ftpusers