如何在 ubuntu 16.04最低配置4.04 里面配置 chroot 环境

Ubuntu 14.04 ftp,ssh环境配置 - yanchengyang09的个人空间 - 中国电子顶级开发网(EETOP)-电子设计论坛、博客、超人气的电子工程师资料分享平台
- Powered by X-Space
Ubuntu 14.04 ftp,ssh环境配置
& 12:01:10
/ 个人分类:
&& ubuntu安装ftp服务器(一般配置) ubuntu安装ftp服务器 1: 安装vsftpd ~$ sudo apt-get install vsftpd&
ubuntu10.10自己装了,这步省略。&2: 配置vsftpd 2.1 修改vsftpd的配置文件。此类配置文件通常位于 /etc 目录下。~$ sudo gedit /etc/vsftpd.conf原文件中不少指令被注释,只要启用部分即可,一下是启用的命令(配置文件中对每一条都有具体说明)listen=YES&&&&&& # 服务器监听anonymous_enable=YES&&&&&& # 匿名访问允许local_enable=YES&&& # 本地主机访问允许write_enable=YES&&& # 写允许anon_upload_enable=YES # 匿名上传允许,默认是NO,嫌麻烦的可以开起来。出了问题我不负责~anon_mkdir_write_enable=YES& # 匿名创建文件夹允许dirmessage_enable=YES& # 进入文件夹允许xferlog_enable=YES&& #& ftp 日志记录允许connect_from_port_20=YES&&&& # 允许使用20号端口作为数据传送的端口secure_chroot_dir=/var/run/vsftpd/empty pam_service_name=vsftpd rsa_cert_file=/etc/ssl/private/vsftpd.pem保存。&2.2& 设置ftp相关目录&&&&&&& 安装完毕后,/srv下会增加一个ftp目录。同时系统会增加一个名为ftp的用户组,可以用~$ sudo cat&&& /etc/shadow 查看, 如 ftp:*:99:7:::。我们在/srv/ftp目录下创建两个分别名为upload和download的目录,分别用于上传和下载。接下来我们为刚才创建的几个目录设置权限,如下: 权限&&&&&&&&&&&&&&&&&&&&&&&&&&& /srv/ftp&&&&&&&&&&&&&&&&&&&& /srv/ftp/upload&&&&&&&&&&&&&&&& /srv/ftp/download用户组(ftp)&&&&&&&&&&& 读&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&& 读写&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&& 读 其他用户&&&&&&&&&&&&&&&&&&& 读&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&& 读写&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&& 读&&&&&&&&&&&&&&&&&&&&&& 执行命令:~$ sudo chmod 755 /home/ftp ~$ sudo chmod 777 /home/ftp/upload ~$ sudo chmod 755 /home/ftp/download &&&&&&& 如此,一方面我们允许了用户组ftp访问/home/ftp (匿名访问);一方面赋予了用户组ftp对/srv/ftp/upload的写权利,因此网络上的用户可以方便地上传文件,但注意,当他们上传后,上传的文件只有root对这些文件拥有权限,也就是说这个目录仅能用于上传,无法下载其中的文件;此外赋予了用户组ftp对 /home/ftp/download的读权利,同时我们拷贝进该目录下的文件对于用户组而言通常都有读权利,因此网络上的用户从此目录下能且仅能下载文件。从而满足了我们预先的要求。&3:启动vsftpd ~$ sudo service vsftpd start查看当前所有进程: ~$ ps -e &2183 ?&&&&&&& 00:00:00 vsftpd &&&&&&& 至此服务器端vsftp的最基本配置已完成,vsftpd已开启。(注意你的防火墙配置,作为简单试验可以直接停用防火墙)&&&&&&& 当然关闭vsftpd进程只需要执行~$ sudo service vsftpd stop,同时还可以使用命令~$ pgrep vsftpd 来查看进程vsftp是否存在。4:vsftpd 设置用户目录,如果你设置了匿名用户也可以登录上传的话~这个可以省了~(1) 增加组 sudo groupadd ftpgroup (2 )修改vsftpd.conf~$ sudo gedit /etc/vsftpd.conf  将底下三行   #chroot_list_enable=YES  # (default follows)  #chroot_list_file=/etc/vsftpd/chroot_list  改为   chroot_list_enable=YES  # (default follows)  chroot_list_file=/etc/vsftpd/chroot_list (3) 增加用户ftpuser并设置其目录为/home/nation/ftp/upload sudo useradd -g ftpgroup -d /home/nation/ftp/upload -M ftpuser(注:G:用户所在的组 d:表示创建用户的自己目录的位置给予指定M:不建立默认的自家目录,也就是说在/home下没有自己的目录)(4 )设置用户口令 passwd ftpuser (5) 编辑chroot_list文件:sudo gedit /etc/vsftpd.chroot_list内容为ftp用户名,每个用户占一行,如:ftpuser (6 )重新启动vsftpd:sudo service vsftpd start网上有很多介绍在Ubuntu下开启SSH服务的文章,但大多数介绍的方法测试后都不太理想,均不能实现远程登录到Ubuntu上,最后分析原因是都没有真正开启ssh-server服务。最终成功的方法如下:   Ubuntu 下安装 OpenSSH Server 是无比轻松的一件事情,需要的命令只有一条:  sudo apt-get install openssh-server&(查看返回的结果,如果没有出错,则用putty、SecureCRT、SSH Secure Shell Client等SSH 客户端软件,输入您服务器的 IP 地址。如果一切正常的话,等一会儿就可以连接上了。并且使用现有的用户名和密码应该就可以登录了。)&  然后确认sshserver是否启动了:(或用“netstat -tlp”命令)  ps -e | grep ssh  如果只有ssh-agent那ssh-server还没有启动,需要/etc/init.d/ssh start,如果看到sshd那说明ssh-server已经启动了。&  ssh-server配置文件位于/ etc/ssh/sshd_config,在这里可以定义SSH的服务端口,默认端口是22,你可以自己定义成其他端口号,如222。然后重启SSH服务:  sudo /etc/init.d/ssh resart  事实上如果没什么特别需求,到这里 OpenSSH Server 就算安装好了。但是进一步设置一下,可以让 OpenSSH 登录时间更短,并且更加安全。这一切都是通过修改 openssh 的配置文件 sshd_config 实现的。  首先,您刚才实验远程登录的时候可能会发现,在输入完用户名后需要等很长一段时间才会提示输入密码。其实这是由于 sshd 需要反查客户端的 dns 信息导致的。我们可以通过禁用这个特性来大幅提高登录的速度。首先,打开 sshd_config 文件:  sudo nano /etc/ssh/sshd_config  找到 GSSAPI options 这一节,将下面两行注释掉:  #GSSAPIAuthentication yes #GSSAPIDelegateCredentials no然后重新启动 ssh 服务即可:  sudo /etc/init.d/ssh restart  再登录试试,应该非常快了吧  利用 PuTTy 通过证书认证登录服务器  SSH 服务中,所有的内容都是加密传输的,安全性基本有保证。但是如果能使用证书认证的话,安全性将会更上一层楼,而且经过一定的设置,还能实现证书认证自动登录的效果。  首先修改 sshd_config 文件,开启证书认证选项:  RSAAuthentication yes PubkeyAuthentication yes AuthorizedKeysFile %h/.ssh/authorized_keys修改完成后重新启动 ssh 服务。  下一步我们需要为 SSH 用户建立私钥和公钥。首先要登录到需要建立密钥的账户下,这里注意退出 root 用户,需要的话用 su 命令切换到其它用户下。然后运行:  ssh-keygen  这里,我们将生成的 key 存放在默认目录下即可。建立的过程中会提示输入 passphrase,这相当于给证书加个密码,也是提高安全性的措施,这样即使证书不小心被人拷走也不怕了。当然如果这个留空的话,后面即可实现 PuTTy 通过证书认证的自动登录。  ssh-keygen 命令会生成两个密钥,首先我们需要将公钥改名留在服务器上:  cd ~/.ssh mv id_rsa.pub authorized_keys然后将私钥 id_rsa 从服务器上复制出来,并删除掉服务器上的 id_rsa 文件。  服务器上的设置就做完了,下面的步骤需要在客户端电脑上来做。首先,我们需要将 id_rsa 文件转化为 PuTTy 支持的格式。这里我们需要利用 PuTTyGEN 这个工具:  点击 PuTTyGen 界面中的 Load 按钮,选择 id_rsa 文件,输入 passphrase(如果有的话),然后再点击 Save PrivateKey 按钮,这样 PuTTy 接受的私钥就做好了。  打开 PuTTy,在 Session 中输入服务器的 IP 地址,在 Connection-&SSH-&Auth 下点击 Browse 按钮,选择刚才生成好的私钥。然后回到 Connection 选项,在 Auto-login username 中输入证书所属的用户名。回到 Session 选项卡,输入个名字点 Save 保存下这个 Session。点击底部的 Open 应该就可以通过证书认证登录到服务器了。如果有 passphrase 的话,登录过程中会要求输入 passphrase,否则将会直接登录到服务器上,非常的方便。&  在 Windows 机上用 Ubuntu ssh 远程登录 Ubuntu 机下载 PuTTY  如何在 Windows 机上拷贝 文件/文件夹 从/到 远程 Ubuntu 机下载 FileZilla借助ubuntu电脑,给安卓手机安装整套ubuntu14.04
具体操作:
一、生成可用的镜像,并安装你喜欢的软件:
1、为ubuntu设置QEMU和ARM二进制以及asdebootstrap支持:
sudo apt-get install debootstrap qemu-user-static qemu-system git gcc-arm-linux-gnueabihf binfmt-support
2、创建镜像文件系统(我创建了3GB的),格式化成ext4,并挂载在/mnt目录中。
dd if=/dev/zero of=ubuntu.img bs=1048576 count=3200
mkfs.ext4 ubuntu.img
sudo mount -o loop ubuntu.img /mnt
注意:4.2以下的安卓,请格式化成ext2。
3、使用debootstrap来部署基础环境,并将qemu-arm-static复制进基本环境中:
HOSTNAME=ubuntu-armhf sudo debootstrap --variant=minbase --foreign --arch armhf trusty /mnt
sudo cp /usr/bin/qemu-arm-static /mnt/usr/bin/
4、用qemu-arm-static完成剩下的部署工作:
LANG=zh_CN.UTF-8 sudo chroot /mnt /usr/bin/qemu-arm-static -cpu cortex-a15 /bin/bash
./debootstrap/debootstrap --second-stage
注意:自己查一下自己的手机cpu型号,改一下 cortex-a15 这个参数。
我的酷派大神f1其实是cortex-a7,但是也许是太新了,现在还不支持,所以选了较为接近的cortex-a15。
5、一旦上面的工作完成了,我们需要安装apt源,并更新:
trusty main restricted universe multiverse& & /etc/apt/sources.list
trusty-security main restricted universe multiverse& && /etc/apt/sources.list
trusty-updates main restricted universe multiverse& && /etc/apt/sources.list
trusty-proposed main restricted universe multiverse& && /etc/apt/sources.list
trusty-backports main restricted universe multiverse& && /etc/apt/sources.list
echo &deb-src
trusty main restricted universe multiverse& && /etc/apt/sources.list
echo &deb-src
trusty-security main restricted universe multiverse& && /etc/apt/sources.list
echo &deb-src
trusty-updates main restricted universe multiverse& && /etc/apt/sources.list
echo &deb-src
trusty-proposed main restricted universe multiverse& && /etc/apt/sources.list
echo &deb-src
trusty-backports main restricted universe multiverse& && /etc/apt/sources.list
apt-key adv --keyserver
--recv-keys 428D7C01
apt-get update
apt-get dist-upgrade
6、配置中文环境,调整时区。
export LANG=&zh_CN.UTF-8&
export LC_ALL=&zh_CN.UTF-8&
chmod -R 777 /var/lib/locales/supported.d/
cd /var/lib/locales/supported.d/
chmod -R 777 /var/lib/locales/supported.d/
echo &ja_JP.UTF-8 UTF-8& &&ja
echo &ja_JP.EUC-JP EUC-JP& &&ja
echo &ko_KR.UTF-8 UTF-8& &&ko
echo &ko_KR.EUC-KR EUC-KR& &&ko
echo &zh_CN.UTF-8 UTF-8& &&zh
echo &zh_TW.UTF-8 UTF-8& &&zh
echo &zh_CN.GB2312 GB2312& &&zh
echo &zh_CN.GBK GBK& &&zh
echo &zh_CN.GB18030 GB18030& &&zh
echo &LANGUAGE=zh_CN:zh:en_US:en& && /etc/environment
echo &LC_CTYPE=zh_CN.UTF-8& && /etc/environment
echo &LANG=zh_CN.UTF-8& && /etc/environment
echo &GST_ID3_TAG_ENCODING=GBK& && /etc/environment
dpkg-reconfigure locales
dpkg-reconfigure tzdata
export LANG=&zh_CN.UTF-8&
export LC_ALL=&zh_CN.UTF-8& #从这句以后,shell内开始显示中文了。
apt-get install xfonts-base xfonts-100dpi xfonts-75dpi xfonts-scalable xfonts-wqy fonts-wqy-microhei fonts-wqy-zenhei
apt-get clean
tzdata要先后选择 6:Asia 和 27. Hong_Kong。(不知道为什么,不能选shanghai,选shanghai则时间不对)
7、然后,你就可以安装各种软件(我安装了kubuntu桌面环境):
apt-get install sudo apt-utils dialog less wget vim net-tools openssh-server \
htop tmux build-essential libevent-dev python-dev python-setuptools \
python-lxml sqlite3 nodejs npm
apt-get install kubuntu-desktop
apt-get clean
apt-get install kubuntu-restricted-extras
apt-get clean
apt-get install language-pack-zh-hans language-pack-zh-hans-base language-pack-kde-zh-hans language-pack-gnome-zh-hans language-pack-gnome-zh-hans-base firefox-locale-zh-hans thunderbird-locale-zh-hans kde-l10n-zhcn
apt-get clean
由于分配的空间比较紧张,所以每install一个大的程序后,都需要clean一下才行。
8、添加拥有sudo权限的用户(注意:其实在安卓的ubuntu里面用不上,里面是root用户直接进入环境的):
adduser ubuntu
addgroup --system admin
echo &admin ALL=(ALL:ALL) ALL& && /etc/sudoers
usermod -G ubuntu,admin,plugdev,audio,video ubuntu
9、创建一个用于再手机系统内启动kde的文件,然后离开chroot环境。
echo &export DISPLAY=127.0.0.1:0& & /bin/starkde
echo &export LANGUAGE=zh_CN:zh& & /bin/starkde
echo &export LC_CTYPE=zh_CN.UTF-8& && /bin/starkde
echo &export LANG=zh_CN.UTF-8& && /bin/starkde
echo &export LC_ALL=&zh_CN.UTF-8& && /bin/starkde
echo &startkde& && /bin/starkde
chmod a+x /bin/starkde
10、为了移植安卓机器,建立一些目录(这里不建立,写到启动脚本里面动态建立也行)然后umount。
sudo mkdir /mnt/sdcard
sudo mkdir /mnt//dev/shm
sudo umount /mnt
二、传递文件给手机,开始在手机内操作
1、压缩img文件,压缩后传给手机,并在手机中建立挂载目录。
压缩后大概有1G,解压后3G,所以手机至少要有4G空间
2、建立启动脚本(为了大家看起来方便,我直接把脚本贴出来了):
脚本xsdldesktop(借用felonwan的命令),xsdldesktop地址:/share/link?shareid=&uk=
解压XF_Desktop.zip复制到sdcard根目录
3、在终端中,依次输入:
mkdir /data/linaro
sh chimg ubuntu.img /data/linaro
这时,如果看到下面的提示
root@LinuxPad:~ $
接下来输入:
cp /sdcard/xsdlinit /usr/bin/
cp /sdcard/xsdldesktop /usr/bin/
chmod +x /usr/bin/xsdlinit
chmod +x /usr/bin/xsdldesktop成功后exit退出
4、最后先打开XserverXSDL,去终端输入:
sh /sdcard/xsdldesktop /sdcard/ubuntu.img /data/linaro starkde :0
直接返回主页去XServerXSDL即可
图片上传到红联频道中。
------分隔线----------------------------如何安装centos的chroot环境
有时候我们对开发对os环境有特定的需求,但是又不想影响当前的环境。这时候我们就可以用chroot环境了。
请注意,安装chroot环境需要root权限。
1)首先,给chroot环境创建一个目录,例如:
mkdir /data/jails/myos
2)从centos的官方网站或者镜像网站对应版本的centos-release文件并安装,例如:
wget centos-release-5-8.el5.centos.x86_64.rpm
rpm -i --nodeps --root=/data/jails/myos centos-release-5-8.el5.centos.x86_64.rpm
3)给chroot环境安装yum工具,这样我们就可以进入chroot环境继续安装其它的软件包:
yum -y --installroot=/data/jails/myos install yum
4)给chroot环境mount一些节点(这里不是必须的,但是如果你需要在chroot环境里面开启某些服务的话,最好做上):
mount --bind /dev /data/jails/myos/dev
mount --bind /proc /data/jails/myos/proc
mount --bind /sys /data/jails/myos/sys
5)搭建完成,进去调整一下时区就大功告成了:
chroot /data/jails/myos
cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
补充)如果你发现你的系统网络有问题,可能是你的DNS设置不对,请参考一下主环境里面的/etc/resolv.conf文件。
作者 火流星X
(window.slotbydup=window.slotbydup || []).push({
id: '2467140',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467141',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467142',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467143',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467148',
container: s,
size: '1000,90',
display: 'inlay-fix'

我要回帖

更多关于 ubuntu14.04网络配置 的文章

 

随机推荐