Ubuntu下各种服务搭建及操作技巧

Ubuntu下搭建TFTP

1、安装软件包

sudo apt-get install tftpd tftp xinetd

2、建立配置文件

/etc/xinetd.d/下建立一个配置文件tftp

sudo vi /etc/xinetd.d/tftp

内容如下

  1. service tftp  
  2. {  
  3.     socket_type = dgram  
  4.     protocol = udp  
  5.     wait = yes  
  6.     user = root  
  7.     server = /usr/sbin/in.tftpd  
  8.     server_args = -s /tftpboot  
  9.     disable = no  
  10.     per_source = 11  
  11.     cps = 100 2  
  12.     flags = IPv4  
  13. }  

3、建立tftp服务文件目录

在上面的配置中有server_args = -s /tftpboot,其中/tftpboot这个目录就是上传文件与下载文件的位置。

sudo mkdir /tftpboot          --创建/tftpboot目录

sudo chmod 777 /tftpboot -R   --设置权限为777

4、重新启动tftp服务

sudo /etc/init.d/xinetd restart  --重启tftp服务器

5、测试

sudo netstat -a | grep tftp      --查看是否启动成功,可以看到udp 0 0 *:tftp *:*



VMware虚拟机中的ubuntu硬盘扩容


1、通过vmUI界面进行扩容基本上是不行的,至少在我的版本上是这样,各种灰色按钮,各种出错;并且,界面扩容失败后若打不开虚拟机,不要慌,只要你扩容之前的那个硬盘文件(我的是ubuntu64.vmdk,全编一个android项目后39G)还在,基本上是可以恢复的,一定要有耐心哟。另外,如果不是服务器级的硬盘,就不要使用快照了,感觉这个功能很坑爹,非常吃硬盘不说,关键是当它吃完你的硬盘后,你想删除快照,对不起,您的硬盘已满,请预留70G空间再删除。于是你这时只有一种选择,就是删掉整个虚拟机。ps:不要试图暴力删除快照,如:删快照到一半时取消,这样会照成你的虚拟机永远进不去也恢复不了,这会使得你在删除整个虚拟机之前丧失备份关键数据的唯一机会。笔者经历了灾难性的数据损失,完全是血的教训。

下面是使用命令行工具扩容。使用vmware提供的命令行工具vmware-vdiskmanager.exe,在windows下运行cmd,转到vmware安装目录,vmware-vdiskmanager.exe可以查看帮助。输入如下命令扩容:vmware-vdiskmanager -x 160Gb "D:\VMware\WinXP\myUbuntu.vmdk"。注:此时要扩容的系统不能在运行,参数 -x表示要扩展虚拟机的硬盘空间,紧随其后的数字是要扩展到的大小。最后是制定要操作的虚拟机磁盘的具体文件。要是路径名中有空格,必须以双括号括起来。

  

 

2、重启虚拟机,发现虚拟机的硬盘是变成50G了,但进入Ubuntu系统后,用df -ah查看发现硬盘还是原先那么大。接下来要分区、指定文件系统,ubuntu才能识别。

 

3、分区。以root权限进ubuntu

fdisk -l,打印当前磁盘分区表,这时我们可以看到磁盘总量的确增加到了前面设置的大小,但是分区还是只有那几个原有的分区。

fdisk /dev/sda         sda就是经过扩容的SCSI硬盘,IDE类型的硬盘对应为hda,这个命令告知下面对该硬盘进行操作。

m,列出帮助

n,添加新分区

p,创建主分区

3,或直接回车选择默认分区号,应该也是3

直接回车,采用默认Start值,此处不选择默认值会浪费空间

再回车,采用默认End

注意!!此时注意看清end - start的大小,如果只有很小的一段空间,需要再添加一个分区,按上述步骤执行,NP,回车

v,检查为分配磁盘大小,若是只有几M或更小则成功。

w,保存并退出,分区完毕

重启ubuntu

 

4、格式化新添加的分区:

mkfs -t ext3 /dev/sda3

 

5、挂载该分区:

手动挂载:sudo mount /dev/sda3  /mnt/sda3 表示将该新分区挂载到/mnt/sda3/这个目录下。注,手动挂载的信息记录在/etc/mtab

或者开机自动挂载,修改文件:gedit /etc/fstab,添加一行

/dev/sda3    /mnt/sda3    ext3   defaults,        0         1

到此便可以使用新分区了,df -ah查看结果

 

6、使用新分区

现在,硬盘中多出来的这80G空间,只有在/dev/sda3下才能用,在其它地方,使用的依然是system分区——也就是原来的那80G。但我要在其它地方存文件怎么办呢,可以用link来解决——把新分区中的内容映射到某个旧分区上,这样占用的新分区的空间,看起来确是存在旧分区某个你需要的位置。

命令例子:

mv /source/juice /mnt/sda3/source
ln -s /mnt/sda3/source/juice /source

这样,就可以像原来那样在/source/juice下做任何操作了,而它们实际发生在/mnt/sda3/source/juice下。

 

//-------------------------------------------------------------------------------------------------------------

 

 

fdisk -l  指令显示出当前分区中有extended类型的大容量分区,:

[root@edes02 ~]# fdisk -l

Disk /dev/sda: 1979.1 GB, 1979119894528 bytes
255 heads, 63 sectors/track, 240614 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x2135c370

Device Boot Start End Blocks Id System
/dev/sda1 1 5 40131 de Dell Utility
Partition 1 does not end on cylinder boundary.
/dev/sda2 * 6 267 2097152 c W95 FAT32 (LBA)
Partition 2 does not end on cylinder boundary.
/dev/sda3 267 330 512000 83 Linux
Partition 3 does not end on cylinder boundary.
/dev/sda4 330 240615 1930084160 5 Extended
Partition 4 does not end on cylinder boundary.

 

则可用以下命令直接扩容:

lvextend -L +100G /dev/mapper/VolGroup-lv_root

/dev/mapper/VolGroup-lv_root

其中/dev/mapper/VolGroup-lv_root是我的主分区

 

扩容成功提示:

resize2fs 1.41.12 (17-May-2010)
Filesystem at /dev/mapper/VolGroup-lv_root is mounted on /; on-line resizing required
old desc_blocks = 4, new_desc_blocks = 35
Performing an on-line resize of /dev/mapper/VolGroup-lv_root to 144179200 (4k) blocks.
The filesystem on /dev/mapper/VolGroup-lv_root is now 144179200 blocks long.

 

现在查看分区:

[root@edes02 ~]# df -lh
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/VolGroup-lv_root 542G 27G 488G 6% /
tmpfs 16G 26M 16G 1% /dev/shm
/dev/sda3 485M 40M 421M 9% /boot
/dev/mapper/VolGroup-lv_home 79G 29G 46G 39% /home




Ubuntu 14.04NFS安装配置

发表于2014 7 21

参考:http://www.linuxidc.com/Linux/2013-08/89154.htm

1、执行命令:sudo apt-get install nfs-kernel-server ;

2、执行命令:mkdir /home/jacobxu/nfs-jacoxu建立一个nfs服务的专有的文件夹;

3、建立好文件夹后,接着执行命令:sudo vi /etc/exports配置nfs;

4、在文章的最后一行添加:/home/jacobxu/nfs-jacoxu *(rw,sync,no_root_squash,no_subtree_check)
/home/jacobxu/nfs-jacoxu *(rw,sync,no_root_squash,no_subtree_check)这一行的含义是:
/home/jacobxu/nfs-jacoxu:与nfs服务客户端共享的目录,这个路径必须和你前面设置的文件的路径一致!
*:允许所有的网段访问,也可以使用具体的IP
rw:挂接此目录的客户端对该共享目录具有读写权限
sync:资料同步写入内存和硬盘
no_root_squashroot用户具有对根目录的完全管理访问权限。
no_subtree_check:不检查父目录的权限。

5、修改完上述配置文件保存退出。

6、执行命令:sudo /etc/init.d/rpcbind restart重启rpcbind 服务。nfs是一个RPC程序,使用它前,需要映射好端口,通过rpcbind设定。

7、执行命令:sudo /etc/init.d/nfs-kernel-server restart重启nfs服务。

8、挂载指令:
sudo mount -t nfs 192.168.111.128:/home/jacobxu/nfs-jacoxu /nfs-jacoxu-node001/
到任意一台服务器中执行挂载指令,则可以将指定ip服务器上的共享路径,挂载到本地。

注:nfs只是一种文件目录共享模式,以本地方式进行访问。而HDFS是一种分布式的文件系统,能够在服务器中进行数据的负载均衡。

9、开机自动挂载:
上述指令 sudo mount -t nfs 192.168.111.128:/home/jacobxu/nfs-jacoxu /nfs-jacoxu-node001/写到 /etc/rc.local文件中

附录: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 共享文件的UIDGID映射匿名用户anonymous,适合公用目录。
no_all_squash 保留共享文件的UIDGID(默认)
root_squash root用户的所有请求映射成如anonymous用户一样的权限(默认)
no_root_squas root用户具有根目录的完全管理访问权限
anonuid=xxx 指定nfs服务器/etc/passwd文件中匿名用户的UID
anongid=xxx 指定nfs服务器/etc/passwd文件中匿名用户的GID




 嵌入式nfs问题解决总结 


刚开始用的ubuntu10.04,无论如何搞都不成功,最后无奈选择 fedora14nfs成功,现记录如下:

1 如果没有安装nfs则安装nfs,每种发行版linux安装方法不同

2 改写 /etc/exports文件,我增加了一行  /root *(sync,rw,no_root_squash)

sync,rw,no_root_squash的意思可以网上查一下,直接搜 nfs配置,多点一个就有介绍了

3 开启nfs

fedora下开启方法 service nfs start  /status/stop/restart

4 保证开发板,WIndows(宿主机)linux(虚拟机)能够互相ping通,注意关闭Windows防火墙及federo的防火墙及SELinux功能

5 开发版上找载NFS,这一步如果这样:mount -t nfs 192.168.1.106:/root share这样执行不成功,显示

svc: failed to register lockdv1 RPC service (errno 111).
lockd_up: makesock failed, error=-111

把上述命令改为:mount -t nfs -o nolock 192.168.1.106:/root share 成功

说是 nfs mount默认是带锁的,所以要取消锁,具体不懂




 关于mount nfs时-o nolock的问题 


 需要将在linux里交叉编译好的程序放在arm上运行,所以首先要将程序copyarm上,选择了nfs

       但在armmount nfs的时候遇到了失败的情况:


       在网上查找解决方案:

        nfs mount 默认选项包括文件锁,依赖于portmap提供的动态端口分配功能。
        解决方法:kill文件锁(lockd)或者mount -o nolock

 

        于是尝试mount -o nolock -t nfs 192.168.1.24:/home/test /mnt/nfs,正常工作。







Ubuntu 14.04 修改密码


安装完Ubuntu 14.04后默认是没有主动设置root密码的,也就无法进入根用户。

  1、用当前登录用户打开终端,在终端输入命令 sudo passwd,输入当前用户的密码然后回车


 

  2、会提示输入新密码,输入完成后回车

  3、然后提示再输入一次新密码以确认,然后回车,设置成功

  linuxidc@ubuntu:~$ sudo passwd

  [sudo] password forlinuxidc:

  输入新的 UNIX 密码:

  重新输入新的 UNIX 密码:

  passwd:已成功更新密码

  linuxidc@ubuntu:~$

  注意:这个新密码就是root的密码,可以与当前用户的密码不同。

  在终端中输入 su root,然后输入root的密码,验证成功即可切换到root用户。在root用户下做完操作后,用exit命令即可退出root用户,退回当前登陆用户。





ubuntu 14.04 install java8  Eclipse

1、下载JDK

从官网下载jdk8

jdk-8u45-linux-i586.gz

2、解压
$ tar -zxvf jdk-8u45-linux-i586.gz
解压出来是一个jdk1.8.0_45文件夹
3、将文件夹移动到安装目录
$ sudo mv jdk1.8.0_45 /usr/local/

或者:

sudo tar xzvf jdk-8u45-linux-i586.gz -C /usr/local

4、配置环境变量 ,更改/etc/profile文件

  sudo gedit /etc/profile

         在文件最后加上如下几行:

export JAVA_HOME=/usr/local/jdk1.8.0_45
export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH
export CLASSPATH=$CLASSPATH:.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib

5、更改默认JDK配置选项 ,依次执行如下命令

 sudo update-alternatives  --install  /usr/bin/java java /usr/local/jdk1.8.0_65/bin/java 300

sudo update-alternatives  --install  /usr/bin/javac javac /usr/local/jdk1.8.0_65/bin/javac 300

sudo update-alternatives  --install  /usr/bin/jar jar /usr/local/jdk1.8.0_65/bin/jar 300
sudo update-alternatives  --install  /usr/bin/javah javah /usr/local/jdk1.8.0_65/bin/javah 300

sudo update-alternatives  --install  /usr/bin/javap javap /usr/local/jdk1.8.0_65/bin/javap 300


eclipse官网下载压缩包                                               

下载地址:http://www.eclipse.org/downloads/


解压缩到/usr/local                                                      

sudo tar xzvf eclipse-standard-luna-R-linux-gtk.tar.gz -C /usr/local

tar-C参数指定了文件解压后所在的目录








本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/383304.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Automake和Autoconf生成Makefile

automake 所产生的 Makefile 除了可以做到程序的自动编译和链接 外,还可以用来生成各种文档(如manual page、info文件),可以将源代码文件包装起来以供发布。所以程序源代码所存放的目录 结构最好符合GNU的标准惯例。下面以hello.…

c++中多态---3(虚析构和纯虚析构,向上类型转化和向下类型转化)

虚析构和纯虚析构 虚析构virtual ~类名(){}类内声明,类内实现解决问题:通过父类指针指向子类对象释放时候不干净的问题 纯虚析构 写法 virtual ~类名(){}0; 类内声明 类外实现 如果出现了纯虚析构函数,这个类也算是抽象类,不可…

嵌入式开发硬件知识札记

三态逻辑 1. 概念 三态指其输出既可以是一般二值逻辑电路,即正常的高电平(逻辑1)或低电平(逻辑0),又可以保持特有的高阻抗状态。高阻态相当于隔断状态(电阻很大,相当于开路&#xff…

《凡人修仙传》中打斗场景(c++多态实现)

我们 要实现打斗场景,第一,我们需要有打斗的双方,一个是英雄,一个是怪物,他们都有自己的属性,比如攻击,防御,血量。其次我们的英雄还会有武器。武器上有一些加成属性,可以…

c++中的文件读写的操作

写文件 ofstreamopen指定打开方式isopen判断是否打开成功ifs<<“数据”ofs.close&#xff08;&#xff09; 读文件 ifstream ifs 指定打开方式ios::in isopen判断是否打开成功 读取有三种方式 #include<iostream>using namespace std;//文件读写头文件#incl…

c++的STL--1概念通述

STL的概念 什么是STL? STL(standard template libaray-标准模板库)&#xff1a;是C标准库的重要组成部分&#xff0c;不仅是一个可复用的组件库&#xff0c;而且 是一个包罗数据结构与算法的软件框架。 STL从广义上分为&#xff1a;容器(container)&#xff0c;算法(algorit…

c++的vector容器

vector容器概念 vector是表示可变大小数组的序列容器。就像数组一样&#xff0c;vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素 进行访问&#xff0c;和数组一样高效。但是又不像数组&#xff0c;它的大小是可以动态改变的&#xff0c;而且它…

新一代数据库技术

新一代非关系型数据库有以下5个主要类型&#xff1a; 面向文件存储&#xff1a;适用于存储海量文件&#xff0c;代表产品MongoDb 列存储(wide column store/column-family)数据库&#xff1a;快速查找相关数据&#xff0c;相关数据被放在同一列中&#xff0c;代表产品Cassandra…

c++中stack容器

Stack 简介 stack 是堆栈容器&#xff0c;是一种“先进后出”的容器。stack 是简单地装饰 deque 容器而成为另外的一种容器。#include stack没有迭代器 Stack所有元素的进出都必须符合“先进后出”的条件&#xff0c;只有stack顶端的元素&#xff0c;才有机会被外界取用&am…

c++中的queue容器

queue容器 队列是一种容器适配器&#xff0c;专门用于在FIFO上下文(先进先出)中操作&#xff0c;其中从容器一端插入元素&#xff0c;另一端 提取元素。 队列作为容器适配器实现&#xff0c;容器适配器即将特定容器类封装作为其底层容器类&#xff0c;queue提供一组特定的 成员…

c++中list容器

list概念 list是可以在常数范围内在任意位置进行插入和删除的序列式容器&#xff0c;并且该容器可以前后双向迭代。list的底层是双向链表结构&#xff0c;双向链表中每个元素存储在互不相关的独立节点中&#xff0c;在节点中通过指针指向 其前一个元素和后一个元素。list与for…

c++中容器(STL)的共性与使用的时机

容器的共通能力 C模板是容器的概念 理论提高&#xff1a;所有容器提供的都是值&#xff08;value&#xff09;语意&#xff0c;而非引用&#xff08;reference&#xff09;语意。容器执 行插入元素的操作时&#xff0c;内部实施拷贝动作。所以 STL 容器内存储的元素必须能够被…

Qt Creator 窗体控件自适应窗口大小布局

常见的软件窗口大小改变&#xff08;最大化、手动改变时&#xff09;需要窗口的部件能够自适应布局&#xff0c;而在Qt的应用程序界面设计中&#xff0c;对于像我一样的初学者如何实现窗口自适应调整还是要绕点弯路的。网上百度了很多&#xff0c;多数说的很含糊&#xff0c;还…

QT子线程与主线程的信号槽通信

最近用QT做一个服务器&#xff0c;众所周知&#xff0c;QT的主线程必须保持畅通&#xff0c;才能刷新UI。所以&#xff0c;网络通信端采用新开线程的方式。在涉及到使用子线程更新Ui上的控件时遇到了点儿麻烦。网上提供了很多同一线程不同类间采用信号槽通信的方式&#xff0c;…

c++中的函数适配器

函数适配器 函数适配器概念 STL中定义了大量的函数对象&#xff0c;但是有时候需要对函数返回值进行进一步的简单计算&#xff0c;或者填上多余的参数&#xff0c;不能直接代入算法&#xff0c;函数适配器实现了这一功能&#xff0c;将一种函数对象转化为另一种符合要求的函数…

c++中STL实现演讲比赛流程

演讲比赛流程 1&#xff09;某市举行一场演讲比赛&#xff0c;共有 24 个人参加&#xff0c;按参加顺序设置参赛号。比赛共三轮&#xff0c;前两 轮为淘汰赛&#xff0c;第三轮为决赛。 2&#xff09;比赛方式&#xff1a;分组比赛 第一轮分为 4 个小组&#xff0c;根据参赛号…

c++实现贪吃蛇

游戏中的实现元素 游戏中元素分为&#xff1a;墙壁&#xff0c;蛇&#xff0c;事物以及蛇的可行区域和右侧的版本号和游戏玩法提示 墙壁 *号表示&#xff0c;代表一个区域范围&#xff0c;也就是蛇的可移动区域&#xff0c;蛇如果碰到墙壁视为死亡&#xff0c; 蛇 分为蛇头&a…

Linux系统编程--1(进程和程序,CPU和MMU,PCB,进程状态)

进程相关概念 程序和进程 程序&#xff1a;是指编译好的二进制文件&#xff0c;在磁盘上&#xff0c;不占用系统资源(cpu、内存、打开的文件、设备、锁…) 进程&#xff1a;是一个抽象的概念&#xff0c;与操作系统原理联系紧密。进程是活跃的程序&#xff08;程序员角度&…

Linux系统编程--2(环境变量,进程控制)

环境变量 环境变量 是指在操作系统中用来指定操作系统运行环境的一些参数 每个人用电脑的习惯不一样&#xff0c;比如一般把文件放到磁盘&#xff0c;怎么管理文件&#xff0c;用什么编译器&#xff0c;所以&#xff0c;环境变量就是根据每个人使用操作系统的习惯来规定一些参…