zoukankan      html  css  js  c++  java
  • 转:Ubuntu下配置tftp服务和NFS服务

    配置tftp

    方法一:(推荐方法)Ubuntu10.04 测试通过

    1.安装TFTP软件

    sudo apt-get install tftp-hpa tftpd-hpa

    tftp-hpa是客户端,tftpd-hpa是服务器端

    2.建立tftpboot目录,作为服务器的目录
    sudo mkdir ~/tftpboot
    释放权限:(服务器目录,需要设置权限为777,chomd 777)
    sudo chmod 777 ~/tftpboot

     

    3.配置TFTP服务器

    sudo gedit /etc/default/tftpd-hpa

    将原来的内容为:

    # /etc/default/tftpd-hpa

    TFTP_USERNAME="tftp"
    #TFTP_DIRECTORY="/var/lib/tftpboot"  #修改为自己需要的路径,与上面创建的目录一致
    TFTP_ADDRESS="0.0.0.0:69"
    #TFTP_OPTIONS="--secure"  #可以通过查看mantftpd,看各种参数的意义

    #修改为

    TFTP_DIRECTORY="/home/shenhao/tftpboot"

    TFTP_OPTIONS="-l -c -s"

    3.重新启动TFTP服务

    sudo service tftpd-hpa restart

    4.测试下

    $ cd ~/tftpboot echo "hello tftp service">>a.txt

    $ echo "hello tftp service,put to tftp serive">>b.txt

    $ tftp localhost

    tftp> get a.txt

    tftp> put b.txt

    tftp> quit 

    其中get是取得文件,put是将文件上传到TFTP服务器上。

    方法二:

    配置tftp服务的步骤: 
    1、安装相关软件包:tftpd(服务端),tftp(客户端),xinetd 
    sudo apt-get install tftpd tftp xinetd

    2、建立配置文件(蓝色的目录是可以更改为其他地址的,例如/home/user/tftpboot) 
    在/etc/xinetd.d/下建立一个配置文件tftp 
    sudo vi tftp 
    在文件中输入以下内容: 
    service tftp 

    socket_type = dgram 
    protocol = udp 
    wait = yes 
    user = root 
    server = /usr/sbin/in.tftpd 
    server_args = -s /tftpboot 
    disable = no 
    per_source = 11 
    cps = 100 2 
    flags = IPv4 

    保存退出

    3、建立tftp服务文件目录(上传文件与下载文件的位置),并且更改其权限 
    sudo mkdir /tftpboot

    sudu chmod 777 /tftpboot

    4、重新启动服务 
    sudo /etc/init.d/xinetd restart 
    至此tftp服务已经安装完成了,下面可以对其进行一下测试。(假设在当前目录下有一个测试文件test.txt) 
    $tftp 192.168.16.2 (本机的ip地址) 
    tftp> get test.txt 
    tftp> quit 
    $

    通过get命令,可以把当前目录下的test.txt文件,通过tftp上传到它的服务文件目录。这时,在/tftpboot下面会出现test.txt文件。通过put命令,可以从/tftpboot下,下载test.txt文件。这样就验证了tftp服务配置的正确性。当文件上传与下载结束后,可以通过quit命令退出。

    严格按照以上步骤配置tftp服务,一般都可以成功。如果出现无法get或者put的时候,可以查看一下防火墙是否关闭。

    -----------------------------------------------------------------------------------------------------

    配置nfs服务器

      
    在ubuntu下安装、配置nfs服务的步骤如下: 
    1、安装nfs 
    Ubuntu上默认是没有安装nfs服务器的,因此我们首先安装nfs服务器端: 
    $sudo apt-get install nfs-kernel-server 
    在一些文档中,提出还需要使用apt-get来手动安装nfs的客户端nfs-common,以及端口映射器portmap,但其实这是没有必要的,因为在安装nfs-kernel-server时,apt会自动为我们把它们安装好。

    2、配置/etc/exports 
    nfs允许挂载的目录及权限在文件/etc/exports中进行了定义。 
    例如,我们要将根目录下的rootfs目录共享出来,那么我们需要在/etc/exports文件末尾添加如下一行:

    /rootfs  *(rw,sync,no_root_squash) 
    其中: /rootfs是要共享的目录,

                *代表允许所有的网络段访问,

                rw是可读写权限,sync是资料同步写入内存和硬盘,

    no_root_squash是nfs客户端分享目录使用者的权限,如果客户端使用的是root用户,那么对于该共享目录而言,该客户端就具有root权限。

    其它nfs常用的参数有:

    ro 
    只读访问 
    rw 读写访问sync 所有数据在请求时写入共享 
    async 
    nfs在写入数据前可以响应请求 
    secure 
    nfs通过1024以下的安全TCP/IP端口发送 
    insecure 
    nfs通过1024以上的端口发送 
    wdelay 
    如果多个用户要写入nfs目录,则归组写入(默认) 
    no_wdelay 
    如果多个用户要写入nfs目录,则立即写入,当使用async时,无需此设置。 
    hide 在nfs共享目录中不共享其子目录 
    no_hide 
    共享nfs目录的子目录 
    subtree_check 
    如果共享/usr/bin之类的子目录时,强制nfs检查父目录的权限(默认) 
    no_subtree_check 
    和上面相对,不检查父目录权限 
    all_squash 
    共享文件的UID和GID映射匿名用户anonymous,适合公用目录。 
    no_all_squash 
    保留共享文件的UID和GID(默认) 
    root_squash 
    root用户的所有请求映射成如anonymous用户一样的权限(默认) 
    no_root_squas 
    root用户具有根目录的完全管理访问权限 
    anonuid=xxx 
    指定nfs服务器/etc/passwd文件中匿名用户的UID 
    anongid=xxx 
    指定nfs服务器/etc/passwd文件中匿名用户的GID

    3、重启服务 
    $sudo /etc/init.d/portmap restart 
    $sudo /etc/init.d/nfs-kernel-server restart

    4、测试nfs 
    此时可以运行以下命令来显示一下共享出来的目录: 
    $showmount -e 
    或者可以使用以下命令把它挂载在本地磁盘上,例如将/rootfs挂载到/mnt下: 
    $sudo mount -t nfs localhost:/rootfs /mnt

    可以运行df命令查看是否挂载成功。查看后可以使用以下命令卸载: 
    $ sudo umount /mnt

    ------------------------------------------------

    关于NFS配置错误

     

    ubuntu测试本机nfs出错:mount.nfs:access denied by server while mounting...

    相信出现这种错误的应该有一些人吧,没关系,一会就帮你搞定。 
    首先运行:sudo vim /etc/exports 
    在其文本后添加 
    /home/work 192.168.1.*(rw,sync,no_root_squash) 
    然后保存退出。

    注意,上面的主机IP可能不能使用*来通配,否则在客户机上会出现访问拒绝,但是如果我们要设置局域网访问呢?怎么办,使用子网掩码例如:10.1.60.0/255.255.254.0即可让10.1.60.*和10.1.61.*都可以访问,还可以使用10.1.60/23这种方式类确定子网。

    /home/work就表示共享目录,当然,你可以随便换成自己喜欢的目录,192.168.1.*,前面三位是你主机的ip地址(怎么获得本机的ip地址?ifconfig命令就可以了) 
    rw:读/写权限,只读权限的参数为ro; 
    sync:数据同步写入内存和硬盘,也可以使用async,此时数据会先暂存于内存中,而不立即写入硬盘。 
    no_root_squash:NFS 服务器共享目录用户的属性,如果用户是 root,那么对于这个共享目录来说就具有 root 的权限。

    下面浅蓝色的文字,可略过去! 
    起用保护机制 
    上面设置了只要在192.168.1.*这个网段的所有IP地址用户都可以访问共享目录,但我只想让一个IP地址访问,比如192.168.1.101(把刚才192.168.1.*直接换成192.168.1.101不行么?应该可以吧,没试过),那么就可以这样设置了。 
    可以通过设定/etc/hosts.deny和/etc/hosts.allow文件来限制网络服务的存取权限。 
    ***/etc/hosts.deny*** 
    portmap:ALL 
    lockd:ALL 
    mountd:ALL 
    rquotad:ALL 
    statd:ALL 
    ***/etc/hosts.allow*** 
    portmap:192.168.1.101 
    lockd:192.168.1.101 
    mountd:192.168.1.101 
    rquotad:192.168.1.101 
    statd:192.168.1.101 
    同时使用这两个文件就会使得只有ip为192.168.1.101的机器使用NFS服务。你的target 
    board的ip地址设定为192.168.1.101,这样就可以了。 
    浅蓝色文字可略过。

    接着执行如下命令: 
    启动端口映射: #sudo 
    /etc/rc.d/init.d/portmap start(如果说找不到,就执行 #sudo /etc/init.d/portmap start) 
    如果这一步不成功,最后也连接不上了。 
    启动NFS 服务: #sudo /etc/rc.d/init.d/nfs start(又找不到,执行 #sudo 
    /etc/init.d/nfs start或#sudo /etc/init.d/nfs-kernel-server start) 
    这两项执行成功 
    的话,就会显示[ok] 
    最后执行:#sudo mount –t nfs 192.168.1.101:/home/work /mnt 
    这里面的192.168.1.101是你自己主机的ip地址,也可以用127.0.0.1来代替自己的主机ip地址,同样可以连接上。/home/work就是刚才在etc/exports里添加的路径。 
    如果在这一步又出错了,呵呵,重新#sudo vim /etc/exports,将“ 192.168.1.*”换成“*”,就这一个星星哦! 
    执行:# ls /mnt

    恭喜你,mnt下是不是有了/home/work里的内容了。

    卸载:#sudo umount /mnt/

    如果上面操作做好了,还是不行,我觉得你应该重启一下机子试一下了! 
    更详细请点击:linux.chinaunix.net/bbs/thread-985579-1-1.html

    提示:挂载根文件时,提示“Warning: unable to open an initial console. ”启动信息问题的解决,以NFS为例。

    清单51 问题现象


    VFS: Mounted root (nfs filesystem).

    Freeing init memory: 144K

    Warning: unable to open an initial console.<启动停到此处>


    根据提示信息定位错误

    查找错误原因: 根据错误提示信息:”Warning: unable to open an initial 
    console.”查看内核源代码。可定位错误提示在内核文件linux-2.6.26.2/init/main.c文件中。

    清单52 分析main.c的调用关系


    asmlinkage void __init start_kernel(void)

    {

    rest_init();

    }

    static void noinline __init_refok rest_init(void)

    __releases(kernel_lock)

    {

    kernel_thread(kernel_init, NULL, CLONE_FS | CLONE_SIGHAND);

    }

    static int __init kernel_init(void * unused)

    {

    init_post();

    return 0;

    }

    static int noinline init_post(void)

    {

    if (sys_open((const char __user *) "/dev/console", O_RDWR, 
    0) < 0)

    printk(KERN_WARNING "Warning: unable to open an initial 
    console.
    \n");

    run_init_process("/sbin/init");

    }通过分析知道内核启动时需要成功打开/dev/console设备,否则给出"Warning: unable to open an 
    initial console.
    "的错误提示。

    //为目标机配置console设备文件节点

    进入你的nfs文件系统的/dev/目录

    sudo mknod console c 5 1

    创建console文件,再重启即可。

    如果还不可以可以试下以下操作:

    内核启动显示:

    Warning: unable to open an initial console. 
    Failed to execute /linuxrc.  Attempting defaults... 
    Kernel panic - not syncing: No init found.  Try passing init= option to kernel.

    解决:

    创建rootfs过程中,在/dev目录下手动创建如下节点:

    sudo mknod -m 660 null c 1 3

    sudo mknod -m 660 console c 5 1

    转自:http://www.cnblogs.com/shenhaocn/archive/2011/03/13/1983042.html

  • 相关阅读:
    Java对象转型
    .Net之路(十二)Cookie对象
    java学习笔记-包
    MongoDB的安装和简单使用
    考试系统维护中对项目管理的一点体会
    .Net之路(十一)StringBuilder和string
    考试系统调试优化总结
    我的2013——走过就有收获
    针对:Arraylist集合无法修改,下一次枚举无法操作的解决方案
    函数第二部分:为什么说动态参数是没有计划好的参数-Python基础前传(11)
  • 原文地址:https://www.cnblogs.com/yyangblog/p/2080636.html
Copyright © 2011-2022 走看看