linux基础

1.1为什么学习linux

linux是一个开源、免费的操作系统,其稳定性、安全性、处理多并发已经得到业界的认可,目前很多中型,大型甚至是巨型项目都在使用linux

linux内核:redhat 、红旗linux、ubuntu、suse、fedora,它们的内核都是一样的(Note:linux其实是一个统称,就比如面条是一个统称,可以有哨子面、阳春面、打卤面等)

-linux系统管理员

-linux系统的维护、配置等

-linux程序员

-需c/c++、java,php、jsp…

-linux软件工程师(PC)

-linux嵌入式开发(单片机、芯片)

1.3如何学习linux

第一阶段:linux平台上的开发,包括vi,gcc,gdb,make,jdk,tomcat,mysql..和linux基本操作

第二阶段:加厚c语言功底《c专家编程》或是java语言

第三阶段:学习unix环境高级编程《unix环境高级编程》

第四阶段:linux应用系统开发/linux嵌入式开发

1.4内容讲解

基础部分

-linux基础知识

-linux常用命令80个

-linux分区/vi/权限…

实用部分

-Samba安装与配置

-linux网络环境配置

-crontab使用

-jdk/apache/mysql/ssh/rpm安装与配置

-linux下java网络编程

-shell初步介绍

1.5推荐书籍

-《鸟哥的Linux的私房菜基础学习篇》 鸟哥、许伟、林彩娥等编著

-《Linux编程从入门到精通》宫虎波编著

-《Linux内核完全剖析》赵炯编著

基础介绍

linux的特点

-免费的/开源

-支持多线程/多用户

-安全性好

-对内存和文件管理优越

linux的缺点

-操作相对困难

linux的历史

-1960时期左右,MIT,即麻省理工学院有一台电脑,使用分时操作系统,只能同时允许30个人通过终端登录

-1965年,MIT、GE、Bell实验室,决定将30è300个人分时系统,multis计划,即火星计划

-1969年,火星计划失败。但Bell的Ken Thompson开发了一个file server system文件系统,在Bell实验室很受欢迎

-在Dennis Ritchie的加入下,1973年,unix诞生,开源,源码内核共享

-IBM:AIX

-Sun:Solaris

-HP: HP unix

-伯克利分校:BSD

-minix系统出现

-Linus Torvalds,芬兰读书,拥有PC 386,1991年计划把minix移植到pc上,1994发布linux 1.0版 linux is not unix,完全没有桌面

-redhat红帽子

-s.u.s.e

-红旗linux

2.2 linux的第一次接触

关机命令

shutdown?h now 立即进行关机

shutdown?r now 现在重新启动计算机

-t sec : -t后面加秒数,即”过几秒后关机”

-k : 不是要真的关机,只是发送警告信息

-r : 在将系统的服务停掉之后就重新启动

-h : 将系统服务停掉后,立即关机

-n : 不经过init程序,直接以shutdown关机

-f : 关机并启动之后,强制略过fsck的磁盘检查

-F : 系统重新启动之后,强制进行fsck的磁盘检查

-c : 取消已经在进行的shutdown命令内容

reboot现在重新启动计算机

进入桌面

startx

用户登录

登录时尽量少用root账户登录,因为它是系统管理员,最大的权限,难免操作失误。可以利用普通用户登录,登录后再用“su -”命令来切换成系统管理员身份

用户注销

在提示符下输入logout即可

vi编辑器的使用3.1什么是vi编辑器

vi编辑器是linux下最有名的编辑器,也是我们学习linux必须掌握的工具,在linux下也可使用vi进行程序的开发,如java程序,c程序

3.2如何使用vi进行开发?

在linux下使用vi开发一个简单的java程序Hello.java,并且在linux下运行成功

-开发步骤

-java程序

-vi Hello.java

-输入i,进入到插入模式

-输入Esc键,进入命令模式

-输入冒号:[wq 表示退出保存,q!表示退出不保存]

-编译javac Hello.java

-运行java Hello

-c程序

-gcc o Hello Hello.cpp[参数o表示可自定义生成的out文件名,否则默认为a. out]

-./Hello

用户管理.目录结构4.1概述

简单介绍

linux的文件系统是采用层级式的树状目录结构,在此结构中的最上层是根目录“/”,然后在此目录下再创建其他的目录

深刻理解linux文件目录是非常重要的

-/

-root,存放root用户的相关文件

-home,存放普通用户的相关文件

-bin,存放常用命令的目录,如vi,su

-sbin,要具有一定权限才可以使用命令

-mnt,默认挂载光驱和软驱的目录

-etc,存放配置的相关文件

-var,存放经常变化的文件,如网络连接的sock文件

-boot,存放引导系统启动的相关文件

-usr,安装一个软件的默认目录,相当于windows下的program files

相对路径与绝对路径:

-只要开头不是/就是属于相对路径的写法.

-绝对路径为:由根目录/,起的文件名或目录名称.如:/home/dmtsai/.bashrc

常用命令介绍

-pwd,显示当前在哪个路径下

linux的用户管理

-useradd 用户名,添加用户

【案例】useradd xiaoming

-passwd 用户名,为新用户设密码

【案例】passwd xiaoming,修改小明的密码

-userdel 用户名,删除用户

【案例】userdel xiaoming,删除用户但保存用户主目录

【案例】userdel ‐r xiaoming,删除用户以及用户主目录

-logout,当前用户推出

-who am i,当前用户是谁

4.2目录、文件默认属性: 的umask使用

一 权限掩码umask

umask是chmod配套的,总共为4位(gid/uid,属主,组权,其它用户的权限),不过通常用到的是后3个,例如你用chmod 755 file(此时这文件的权限是属主读(4)+写(2)+执行(1),同组的和其它用户有读写权限)

二 umask的作用

默认情况下的umask值是022(可以用umask命令查看),此时你建立的文件默认权限是644(6-0,6-2,6-2),建立的目录的默认 权限是755(7-0,7-2,7-2),可以用ls -l验证一下哦 现在应该知道umask的用途了吧,它是为了控制默认权限,不要使默认的文件和目录具有全权而设的

三 修改umask值

知道了umask的作用后,你可以修改umask的值了,例如:umask 024则以后建立的文件和目录的默认权限就为642,753了

四 将umask值保存到环境文件

若要长期修改umask的值,可以把它写进/etc/profile或~/.profile或~/.bash_profile中,大家应该知道这几个文件是干什么用的吧。

您知道当你建立一个新的档案或目录时,他的预设属性会是什么吗?呵呵!那就与 umask 有关了!那么 umask 是在搞什么呢?基本上, umask 就是指定『目前使用者在建立档案或目录时候的属性默认值』,那么如何得知或设定 umask 呢?他的指定条件以底下的方式来指定:语法:

[root @testroot]# umask0022[root@vbird test]# umask 002 <==后面接 3 个数字![root@vbird test]# umask0002

说明:查看 umask 数值为直接输入 umask 即可,而设定呢?没错!就是 umask 之后接三个数字!那么如何来指定呢?主要还是跟 Linux 的档案属性(那九个属性, r, w, x )有关的,而且是以分数的那一个关系为例的,而有底下的规则为辅:

若使用者建立为『档案』则预设『没有可执行 ( x ) 项目』,亦即只有 rw 这两个项目,也就是最大为 666 分

–rw-rw-rw-

若使用者建立为『目录』,则由于 x 与是否可以进入此目录有关,因此预设为所有权限均开放,亦即为 777 分

drwxrwxrwx

常用命令5.1 linux的常用命令

-init [0123456],指定系统运行级别,类似windows的正常运行模式或安全模式

-0:关机

-1:单用户

-2:多用户状态没有网络服务

-3:多用户状态有网络服务

-4:系统未使用保留给用户

-5:图形界面

-6:系统重启

常用运行级别是3和5,要修改默认的运行级别可改文件/etc/inittab的id:5:initdefault:这一行中的数字

FAQ:不小心设置了6,导致系统启动-重启-启动循环,怎么办?

-在进入grub引导界面时,在数秒的时候,请输入 e

-然后选中第二行,输入e

-在出现的界面里,输入1【1表示单用户级别】,1的前面需要加一个空格,单用户模式既可以修改模式,又可以修改密码,Enter

-返回后,按b

-pwd,显示当前工作目录(print working directory)

-pwd -p 显示出实际路径,而非使用link路径.

-cd,改变目录

-ls,列出文件和目录

-ls ‐a,显示目录下的所有文件,包括隐藏文件

-ls ‐l,显示长列表格式

-mkdir,建立目录(make directory)

–m :设置文件的权限,直接设置,不要管默认权限.如:mkdir –m 711 test2

–p :帮助你完成直接建立所需要的目录递归.(建立多级目录,如:test1/test2/test3/test4)

-rmdir,删除空目录(注:只能删除空目录,删除目录下所有文件可用:rm –rf test)

-touch,建立空文件与修改文件时间

-mtime (modification time) : 当该文件的”文件的内容”更改时,就会更新这个时间。

-ctime (status time) : 当文件的”状态”改变时,就会更新这个时间,如:更改权限与属性时。

-atime (access time) : 当”读取文件内容”时,就会更新这个读取时间.

-例ls -l/etc/man.config 默认是显示mtime 修改时间

-ls -l –time=atime/etc/man.config 显示访问时间

-ls -l –time=ctime/etc/man.config 显示状态时间

-touch [-acdmt] 文件名

–a: 仅修改access time

–c: 仅修改时间,而不建立文件

–d: 后面可以接日期,也可以使用 –date=”日期或时间”

–m: 仅修改mtime

–t: 后面可以接时间,格式为 [YYMMDDhhmm]

-cp,复制命令

–a 该选项通常在拷贝目录时使用。它保留链接、文件属性,并递归地拷贝目

录,其作用等于-pdr选项的组合。

–d 若源文件为连接文件的性情(link file),拷贝时保留链接而不是所指向的文件。

–f 删除已经存在的目标文件而不提示。

–i 和f选项相反,在覆盖目标文件之前将给出提示要求用户确认。回答y时目

标文件将被覆盖,是交互式拷贝。

–p 此时cp除复制源文件的内容外,还将把其修改时间和访问权限也复制到新

文件中。

–r 若给出的源文件是一目录文件,此时cp将递归复制该目录下所有的子目录

和文件。此时目标文件必须为一个目录名。

–l 不作拷贝,只是链接文件。

–s 复制成符号连接文件(symbolic link),即”快捷方式”文件.

–u 若目标文件比源文件旧,更新目标文件

-需要说明的是,为防止用户在不经意的情况下用cp命令破坏另一个文件,如用户指定的目标文件名已存在,用cp命令拷贝文件后,这个文件就会被新源文件覆盖,因此,建议用户在使用cp命令拷贝文件时,最好使用i选项。备份一般用–a, 复制文件给他人时一般用不加参数.

【案例】cp ‐r dir1 dir2,递归复制命令(复制子目录信息)

-mv,移动文件和改文件名(重命名) (鸟哥linux第二版 p123页)

-rm,删除文件和目录

-rm ‐rf *,删除所有内容,包含目录和文件,r表示递归,f表示强制

-ln,ln [-sf] 源文件 目标文件 (建立符号连接,类似于建立某个文件的快捷方式)

u ( 鸟哥linux第二版 p153页)

-‐s 如果ln不加任何参数就进行硬连接, -s 就是符号连接

–f 如果目标文件存在时,就主动将目标文件直接删除后再建立.

【案例】ln ‐s /etc/inittab inittab,inittab指向实际文件/etc/inittab inittab

-more,显示文件内容带分页,ctrl + page up上翻,长空格下翻

-less,显示文件内容带分页

-grep,在文本中查询内容

-grep [-acinV]‘搜索字符串’ filename (鸟哥linux第二版 p233页)

–a : 将二进制文件以文本文件的方式搜索数据

–c : 计算找到’搜索字符串’的次数

–i : 忽略大小写不同,所以大小写视为相同

–n : 顺便输出行号

–v : 反向选择,即显示出没有’搜索字符串’内容的那一行

【案例】假设存在某个文件aaa.java中含有shunping关键字,此时可以使用grep名命令来查找,grep -n “shunping”aaa.java,n表示在第n行出现

-|,管道命令,在linux和unix系统

-怎么理解?把上一个命令的结果交给|后面的命令处理

【案例】ls ‐l /etc/ | more

-man [command],帮助,类似于dos中的help; man实际为manual (操作说明),

5.2搜索文件find、which、whereis、locate:

-which 寻找“执行文件”

–a 将所有可找到的命令均列出,而不仅仅列出第一个找到的命令名称

-whereis 寻找特定文件 whereis [-bmsu] 文件或目录

–b : 只找二进制文件

–m : 只找在帮助文件manual路径下的文件

–s : 只找源文件

–u : 没有帮助文件的文件

-locate [filename]

-例: locate passwd

-find,搜索文件及目录。在linux中,因为文件系统是以级别式的结构来组成的,所以要在整个系统中找到特定的文件和目录并不是件容易的事。而“find”命令可以解决上述问题(鸟哥linux第二版 p137页)

-在特定的目录下搜索并显示指定名称的文件和目录

【案例】find / -name man:意思是说从根目录开始搜索名称为man的文件或目录

-搜索一段时间内被存取/变更的文件或目录

【案例】find /home -amin -10:十分钟内存取的文件或目录

【案例】find /home -atime -10:十小时内存取的文件或目录

【案例】find /home -cmin -10:十分钟内更改过的文件或目录

【案例】find /home -ctime +10:十小时前更改过的文件或目录

-搜索指定大小的文件

【案例】find /home -size +10k:意思是说查找/home目录下大小为10k的文件

-重定向命令

-ls -l >a.txt,列表的内容写入文件a.txt中(覆盖写)

-ls -al >>aa.txt,列表的内容追加到文件aa.txt的末尾

-从文件中输入信息:database_program< database_data

-en,查看环境变量

-压缩和解压

-以zip和unzip处理.zip文件

-zip命令的基本使用方法

-zip file.zip *:zip后接压缩后的文件名,在它的后面输入要压缩的文件即可

-压缩后,自动删除原文件

【案例】zip m file.zip to.txt:把to.txt文件压缩成file.zip文件,to.txt会自动删除的

-将子目录一起压缩

【案例】zip ‐r file.zip *:将当前目录下的子目录一起压缩

-忽略子目录的内容

【案例】zip ‐j file.zip *

-将已压缩的或没有必要压缩的文件去掉

【案例】zip ‐n .mpg: .jpg: .gif:第一种文件中间要用“:”分开

-压缩某一日之后的文件

【案例】zip ‐t 102002 file.zip:将当前目录下在2002年10月20日之后文件压缩

-不压缩链接文件的原文件

【案例】zip ‐y file.zip *

-压缩率问题,-1~-9,其中-9的压缩率最高

【案例】zip -9 file.zip *

-将不需要压缩的文件排除在外

【案例】zip file.zip * -x file2.txt:在压缩时,将当前目录内的file2.txt文件排除在外

-以unzip命令进行.zip文件的解压缩

-直接解压缩文件

【案例】unzip file.zip

-排除不需要解压缩的文件

【案例】unzip file.zip ‐x file2:除了file2文件外,其他的文件都解压缩

-查看压缩包的内容

【案例】unzip ‐Z file.zip:查看file.zip压缩包的内容,也可以使用“-l”

“-v”来查看压缩包的内容

-以gzip和gunzip处理.gz文件

-chattr和lsattr命令详解

-chattr命令的作用很大,其中一些功能是由Linux内核版本来支持的,如果Linux内核版本低于2.2,那么许多功能不能实现。同样-D检查压缩文件中的错误的功能,需要2.5.19以上内核才能支持。另外,通过chattr命令修改属性能够提高系统的安全性,但是它并不适合所有的目录。chattr命令不能保护/、/dev、/tmp、/var目录。

-lsattr比较简单,只是显示文件的属性【案例】 [root]# lsattr

—-ia—j—./lsattr_test

这两个命令是用来改变文件、目录属性的,和chmod,ls这些命令相比,chmod只是改变文件的读写、执行权限,更底层的属性控制是由chattr来改变的。

-chattr命令的用法:chattr [+ – =] [ASacdistu]

最关键的是在[mode]部分,[mode]部分是由+-=和[ASacDdIijsTtu]这些字符组合的,这部分是用来控制文件的属性。

-+ :在原有参数设定基础上,追加参数。

— :在原有参数设定基础上,移除参数。

-= :更新为指定参数设定。

-A:文件或目录的 atime (accesstime)不可被修改(modified), 可以有效预防例如手提电脑磁盘I/O错误的发生。

-S:硬盘I/O同步选项,功能类似sync。

-a:即append,设定该参数后,只能向文件中添加数据,而不能删除,多用于服务器日志文件安全,只有root才能设定这个属性。

-c:即compresse,设定文件是否经压缩后再存储。读取时需要经过自动解压操作。

-d:即no dump,设定文件不能成为dump程序的备份目标。

-i:设定文件不能被删除、改名、设定链接关系,同时不能写入或新增内容。i参数对于文件 系统的安全设置有很大帮助。

-j:即journal,设定此参数使得当通过mount参数:data=ordered 或者 data=writeback 挂 载的文件系统,文件在写入时会先被记录(在journal中)。如果filesystem被设定参数为 data=journal,则该参数自动失效。

-s:保密性地删除文件或目录,即硬盘空间被全部收回。

-u:与s相反,当设定为u时,数据内容其实还存在磁盘中,可以用于undeletion.

各参数选项中常用到的是a和i。a选项强制只可添加不可删除,多用于日志系统的安全设定。而i是更为严格的安全设定,只有superuser (root) 或具有CAP_LINUX_IMMUTABLE处理能力(标识)的进程能够施加该选项。

【案例】1、用chattr命令防止系统中某个关键文件被修改

# chattr +i/etc/fstab

然后试一下rm mv rename等命令操作于该文件,都是得到Operation not permitted 的结果【案例】2、让某个文件只能往里面追加内容,不能删除,一些日志文件适用于这种操作  # chattr +a /data1/user_act.log

5.3 linux系统中last命令的用法

1.作用linux系统中last命令的作用是显示近期用户或终端的登录情况,它的使用权限是所有用户。通过last命令查看该程序的log,管理员可以获知谁曾经或企图连接系统。

2.格式

last [—R] [—n][-ffile][-t tty][—h节点][-I —IP][—1][-y][ID]

3.主要参数

– R: 省略hostname的栏位

-n:指定输出记录的条数。

-f file:指定用文件file作为查询用的log文件。

-t tty:只显示指定的虚拟控制台上登录情况。

-h 节点:只显示指定的节点上的登录情况。

-i IP:只显示指定的IP上登录的情况。

-1:用IP来显示远端地址。

-y:显示记录的年、月、日。

-ID:知道查询的用户名。

-x:显示系统关闭、用户登录和退出的历史。

范例:shell>> last -R -2user3 pts/1 Mon Aug 14 20:42 still logged inuser3 pts/0 Mon Aug 14 19:59 still logged inwtmp begins Tue Aug 1 19:01:10 2007 ### /var/log/wtmp

shell>> last -2 user1user1 pts/0 140.119.217.115 Mon Aug 14 18:37 – 18:40 (00:03)user1 pts/0 140.119.217.115 Mon Aug 14 17:22 – 17:24 (00:02)wtmp begins Tue Aug 1 19:01:10 2007

5.4 linux wc命令详解

功能说明:计算字数。

语   法:wc [-clw][–help][–version][文件…]

补充说明:利用wc指令我们可以计算文件的Byte数、字数、或是列数,若不指定任何文件名称,或是所给予的文件名为"-",则wc指令会从标准输入设备读取数据。假设不给予其参数,wc指令会一并显示列数、字数和Byte数

  参   数:-c 只显示Byte数,亦即字符数;

-l 只显示列数;

-w 只显示字数;

–help 在线帮助;

–version 显示版本信息。

范例:

计算文本文件TopGun的列数、字数和字符数:

$ wc TopGun


文件权限.用户组6.1用户组

在linux中的每个用户必须属于一个组,不能独立于组外。在linux中每个文件有所有者、所在组、其它组的概念

-所有者

-所在组

-其它组

-改变用户所在的组

所有者

一般为文件的创建者,谁创建了该文件,就天然的成为该文件的所有者

用ls ‐ahl命令可以看到文件的所有者

也可以使用chown 用户名文件名来修改文件的所有者

文件所在组

当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组

用ls ‐ahl命令可以看到文件的所有组

也可以使用chgrp 组名文件名来修改文件所在的组

其它组

除开文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组

6.2文件权限

ls

-l中显示的内容如下:

-rwxrw-r‐-1 root root 1213 Feb 2 09:39 abc

-10个字符确定不同用户能对文件干什么

-第一个字符代表文件(-)、目录(d),链接(l)

-其余字符每3个一组(rwx),读(r)、写(w)、执行(x)

-第一组rwx:文件所有者的权限是读、写和执行

-第二组rw-:与文件所有者同一组的用户的权限是读、写但不能执行

-第三组r–:不与文件所有者同组的其他用户的权限是读不能写和执行

也可用数字表示为:r=4,w=2,x=1 因此rwx=4+2+1=7

-1 表示连接的文件数

-root 表示用户

-root表示用户所在的组

-1213 表示文件大小(字节)

-Feb 2 09:39 表示最后修改日期

-abc 表示文件名

改变权限的命令

chmod 改变文件或目录的权限

chmod 755 abc:赋予abc权限rwxr-xr-x

chmod u=rwx,g=rx,o=rx abc:同上u=用户权限,g=组权限,o=不同组其他用户权限

chmod u-x,g+w abc:给abc去除用户执行的权限,增加组写的权限

chmod a+r abc:给所有用户添加读的权限

改变所有者(chown)和用户组(chgrp)命令

chown xiaoming abc:改变abc的所有者为xiaoming

chgrp root abc:改变abc所属的组为root

chown root ./abc:改变abc这个目录的所有者是root

chown ‐R root ./abc:改变abc这个目录及其下面所有的文件和目录的所有者是root

改变用户所在组

在添加用户时,可以指定将该用户添加到哪个组中,同样用root的管理权限可以改变某个用户所在的组

-usermod ‐g组名用户名

你可以用

-usermod ‐d目录名用户名,改变该用户登录的初始目录

【综合案例】

【题1.1】建立两个用户组group1和group2,以及三个用户dennis、daniel、abigale,并且将前2个用户分配在group1用户组下,后一个分配在group2用户组下

【题1.2】以dennis用户登录,创建一个Hello.java文件

【题1.3】以daniel用户登录,观察是否可以访问/home/dennis目录以及读或写其创建的Hello.java文件

【题1.4】以dennis用户登录,修改目录/home/dennis及Hello.java文件的读写权限(更正:修改目录权限的时候,应该使用770,而不是760,否则权限不足)

【题1.5】重复【题1.3】

【题1.6】改变abigale的用户组由group2变为group1

然后,可以使用cat /etc/passwd查看并确定

【参考】

-groupadd 组名,在linux中添加组

-vi /etc/group,查看linux中所有组信息,可以看可以编辑

-cat /etc/group,查看linux中所有组信息,只可以看不可以编辑

-useradd ‐g组名用户名,创建用户的同时指定将该用户分配到哪个组下

-vi /etc/passwd,查看linux中所有用户信息,可以看可以编辑

-cat /etc/passwd,查看linux中所有用户信息,只可以看不可以编辑

J2EE环境配置7.1 J2EE环境搭建

jdk安装步骤

-把mypackage.iso挂载到linux操作系统上

-在vm做好配置

-mount /mnt/cdrom,挂载光驱

-unmount /mnt/cdrom,卸载光驱

-把安装文件拷贝到/home

-cp 文件 /home

-安装

-./j2sdk-1_4_2_19-linux-i586.bin

-查看一个文件/etc/profile [环境配置文件]

-配置先前安装的jdk

eclipse安装步骤

-挂载共享文件

-把安装文件拷贝到/home

-cp 文件 /home

-安装

-tar ‐zxvf eclipse-SDK-3.2.1-linux-gtk.tar.gz

-进入图形界面,运行eclipse需要桌面支持

-startx

-启动eclipse

-./eclipse

MyEclipse安装步骤

-挂载共享文件

-把安装文件拷贝到/home

-cp 文件 /home

-安装

-./MyEclipseEnterpriseWorkbenchInstaller_5_1_0GA_E3_2_1.bin

-注意点

-进入图形界面安装支持,否则报错

-选择已安装的eclipse的主目录

-重新启动eclipse

-./eclipse &

-这时会发现,菜单栏上多了一个MyEclipse选项

tomcat安装步骤

我们知道java ee的服务器有tomcat、jboss、weblogic、websphere、resin…这些都可以安装到linux下,我们给人家安装tomcat,安装步骤如下:

-挂载共享文件

-把安装文件拷贝到/home

-cp 文件 /home

-安装

-tar ‐zxvf jakarta-tomcat-5.0.30.tar.gz

-测试

-编写一个简单的jsp页面

-配置tomcat和jdk

linux分区详解8.1概述

硬盘的分区主要分为基本分区(Primary Portion)和扩展分区(ExtensionPortion)两种。只是针对一个硬盘来讲,基本分区和扩展分区的数目之和不能大于4个,且基本分区可以马上被使用但不能再分区。扩展分区必须再进行分区后才能使用,也就是说它必须还要进行二次分区。那么有扩展分区再分下去的是什么呢?它就是逻辑分区(Logical Portion),而且逻辑分区没有数量上限制

对windows用户来说,有几个分区就有几个驱动器,并且每个分区都会获得一个字母标识符,然后就可以选用这个字母来指定在这个分区上的文件和目录。它们的文件结构都是独立的,非常好理解。但对这些用户初上手Redhat Linux,可就有点恼人了。因为对RedhatLinux用户来说无论有几个分区,分给哪一个目录使用,它归根结底就只有一个根目录、一个独立且唯一的文件结构。Redhat Linux中每个分区都是用来组成整个文件系统的一部分。因为它采用了一种叫“载入”的处理方法,它的整个文件系统中包含了一整套的文件和目录,并将一个分区和一个目录联系起来。这时要载入的那个分区将使它的存储空间在这个目录下获得

8.2硬盘

对于IDE硬盘,驱动器标识符为“hdx~”,其中“hd”表明分区所在设备的类型,这里是指IDE硬盘了。“x”为盘号(a为基本盘,b为基本从属盘,c为辅助主盘,d为辅助从属盘),“~”代表分区,前四个分区用数字1到4表示,它们是主分区或扩展分区,从5开始就是逻辑分区。例如:hda3表示为第一个IDE硬盘上的第三个主分区或扩展分区,hdb2表示为第二个IDE硬盘上的第二个主分区或扩展分区

对于SCSI硬盘则标识为“sdx~”,SCSI硬盘是用“sd”来表示分区所在设备的类型的,其余则和IDE硬盘的表示方法一样

8.3几个重要命令8.3.1读取文件系统的信息可以用:dumpe2fs命令来读取.

【案例】dumpe2fs /dev/sda1

8.3.2挂载命令

mount[-a] [设备名称] [挂载点](鸟哥linux第二版 p162)

mount[-tonL] 设备名称代号载入点

特别说明:在挂载光驱时,可直接使用 mount /mnt/cdrom

【案例】mount /dev/sda1 /test/

卸载命令

umount[挂载点]

【案例】umount /test/

8.3.3查看磁盘使用情况

df[-ahikHTm] [目录或文件名]

–a : 列出所有的文件系统,包括系统挺有的 /proc 等文件系统

–k : 以KB为单位显示各文件系统.

–m : 以MB为单位显示各文件系统.

–h : 以GB、MB、KB等格式显示。

–H :以M=1000K取代M=1024K 的计算方式。

–T :连同该分区的文件系统名(例如ext3)一起列出。

–i : 不用硬盘容量,而以inode的数量来显示。

-‐l

-df [目录全路径],查看某个目录是在哪个分区

du [-ahskm] [文件或目录名称] (鸟哥linux第二版 p151)

–a : 列出所有的文件与目录容量,因为仅统计目录下面的文件量而已

–h : 以人们易读的容量格式(G/M)显示

–s : 列出问题,不列出每个目录占用的容量

–k : 以KB列出容量显示

–m : 以MB列出容量显示

8.3.4查看linux系统分区具体情况

fdisk[‐l]设备名称 (鸟哥linux第二版 p155)

-不加 –l 时就会进入fdisk,里面可以n新建分区,d删除分区,p列出当前的分区,q不存储离开,这很重要,w写入分区表后离开,这个比较危险,要注意.

8.3.5磁盘格式化

mke2fs[-bicLj] 设备名称(鸟哥linux第二版 p159)

–b : 可以设置每个块的大小,当前支持1024、2048、4096字节3种。

–I : 给一个inode多少容量

–c : 检查磁盘错误,仅执行一次–c 时,会进行快速读取测试,如果执行两次 -c –c,会测试读写(read-write)会很慢。

–L : 后面可以接卷材(Labe1),这个卷材是有用的。

–j : 本来mke2fs是EXT2,加上-j后,会主动加入日志而灰飞烟灭ext3.

8.3.6磁盘检验:fsck、badblocks

fsck [-AtCary] 设备名称(鸟哥linux第二版 p161)

badblocks [-svw] 设备名称

linux安装演示shell介绍10.1概述

每个人在成功登陆linux后,系统会出现不同的提示符号,例如$、~、#等,然后你就可以开始输入需要的命令,若是命令正确,系统就会依据命令的要求来执行,直到注销系统为止;在登录到注销期间,输入的每个命令都会经过解释及执行。而这个负责的机制就是shell

10.2 shell编程

其实作为命令语言互动式地解释和执行用户输入的命令只是shell功能的一个方面。shell还可以用来进行程序设计。它提供了定义变量和参数的手段以及丰富的程序控制结构。使用shell编程类似于DOS中批处理文件,称为shell script,又叫shell程序或shell命令文件

10.3 shell的分类

Shell名称

开发者

命令名称

Bourne

S.R.Bourne

/bin/sh

C

Bill Joy

/bin/csh

Korn

David

/bin/ksh

10.4 shell的使用

命令历史和互动:用上下箭头键可以重复以前所输入的命令

命令完成功能:用tab键能自动完成相关命令,再次按tab可得到清单

[Ctrl]+c 中断当前命令的组合键,

[Ctrl]+d 键盘输入结束,可以用来取代exit的输入.

shell脚本文件:

-是一个文本文件

-命令的集合

-有执行的权限

-执行方式(./文件名)

用户登录后自动执行的shell脚本文件

-.bashrc位于主目录下,它之前执行系统的脚本/etc/bashrc主要是基本配置数据

-配置.bashrc文件可以指定某些程序在用户登录的时候就自动启动

-.bash_profile位于主目录下,它之前执行系统的脚本/etc/profile主要是配置环境变量

用export可以临时加入一个系统路径,如export PATH=$PATH:$HOME/bin:/root/test/t1,输出环境PATH,引用原来的值$PATH,$HOME表示工作主目录,:是路径分隔符

-已经定义好的环境变量

-SHELL:默认shell

-PATH:路径

-USER:当前登录用户的用户名

-显示变量内容

-echo $SHELL

-echo $USER

-echo $PATH

变量键盘读取、数组、与声明:read、array、declare

-read 格式:read [-pt] variable(鸟哥linux第二版 p213)

–p : 后面可以接提示符

–t : 后面可以接等待秒数

【案例】read -p “Please keyin your name: ” –t 30 name

-declare/typeset 格式: declare [-aixr] variable

–a : 将后面的variable定义为数组(array)

–i : 将后面的variable定义为整数数字(integer)

–x : 用法与export一样,就是将后面的variable变成环境变量

–r : 将一个variable的变量设置成只读,变量不可以更改内容,也不能取消设置

【案例】delare –i sum=100+200+300

-array 格式:var[index]=content

-输入:

-var[1]=”small min”

-var[2]=”big min”

-var[3]=”nice min”

-读取: echo “${var[1]}, ${var[2]}, ${var[3]}”

shell通配符

-*代表多个字母或数字

-?代表一个字母或数字

【案例】ls a* ls a? ls f080[1-6].tif

-转义字符\

【案例】ls /mnt/win1/My\Documents

引号

【案例】export NAME=Michael

echo Welcome $NAME, the dateis date

-单引号:不处理任何变量和命令

【案例】echo ‘Welcome $NAME, the date is date ’

-双引号:处理变量但不处理命令

【案例】echo “Welcome $NAME, the date is date “

-反引号:把引号中的每个单词作为一个命令,如果是变量则先求值然后作为一个命令处理

【案例】echo “Welcome $NAME, the date is `date` “

Linux echo命令。

功能说明:显示文字。

语 法:echo [-ne][字符串]或 echo [–help][–version]

补充说明:echo会将输入的字符串送往标准输出。输出的字符串间以空白字符隔开, 并在最后加上换行号。

参 数:-n 不要在最后自动换行

-e 若字符串中出现以下字符,则特别加以处理,而不会将它当成一般文字输出:

-\a 发出警告声;

-\b 删除前一个字符;

-\c 最后不加上换行符号;

-\f 换行但光标仍旧停留在原来的位置;

-\n 换行且光标移至行首;

-\r 光标移至行首,但不换行;

-\t 插入tab;

-\v 与\f相同;

-\\ 插入\字符;

-\nnn 插入nnn(八进制)所代表的ASCII字符;

—help 显示帮助

—version 显示版本信息

别名

-命令:alias显示系统当前定义的所有alias

【案例】alias cp=’cp -i’

【案例】alias li=’ls –l –color=tty’

补充说明:用户可利用alias,自定指令的别名。若仅输入alias,则可列出目前所有的别名设置。 alias的效力仅及于该次登入的操作。若要每次登入是即自动设好别名,可在/etc/profile或自己的~/.bashrc中设定指令的别名。

还有,如果你想给每一位用户都生效的别名,请把alias la=’ls -al’一行加在/etc/bashrc最后面,bashrc是环境变量的配置文件 /etc/bashrc和~/.bashrc区别就在于一个是设置给全系统一个是设置给单用户使用有,如果你想给每一位用户都生效的别名,请把alias la=’ls -al’一行加在/etc/bashrc最后面,bashrc是环境变量的配置文件 /etc/bashrc和~/.bashrc区别就在于一个是设置给全系统一个是设置给单用户使用

shell的修改

chsh–s 输入新的shell

查阅历史记录

-history,查看使用过的命令的历史记录

-history 5,此项说明会显示最近使用的5个命令

-!5,此项说明执行历史编号为5的命令

-!ls,此项说明执行最后一次以“ls”开头的命令

环境变量的说明: env、set可以用这两个命令查看一些环境变量的说明,直接输入即可。

提示符的设置:PS1=’[\u@\h \W \]\$’ 具体参考: (鸟哥linux第二版 p208\p210)

$系统变量

$#: 命令行参数个数

$n: 命令行参数,n为非负整数.

$0: 表示程序名称

$1: 表示第一个命令行参数

$?: 前一条命令的返回码

$$: 本进程的进程ID

$!: 上一进程的进程ID

tcp.ip基础11.1概述

TCP/IP是unix/linux世界的网络基础,在某种意义上,unix网络就是TCP/IP,而且TCP/IP就是网络互联的标准。它不是一个独立的协议,而是一组协议(TCP、IP、UDP、ARP等协议)

每个Internet上的主机和路由器都有一个IP地址,它包括网络号和主机号,现在所用的IP地址都是32位的。IP地址按照国际标准划分为A、B、C、D、E五种类型

.网络环境配置12.1第一种方法

-用root身份登录,运行setup命令进入到text mode setuputility对网络进行配置,这里可以进行IP、子网掩码、默认网关、DNS的配置

-这时网卡的配置没有生效,运行/etc/rc.d/init.d/network restart命令我们刚才做的设置才生效

-ifconfig

12.2第二种方法

-ifconfig eth0x.x.x.x 对网卡进行设置

-ifconfig eth0network x.x.x.x 对子网掩码设置

-对广播地址和DNS使用默认的

Note:这样配置网络将会立即生效,但是是临时生效

12.3第三种方法

-修改/etc/sysconfig/network-scripts/ifcfg-eth0这个文件里各个属性可以修改,包括IP、子网掩码、广播地址、默认网关等

-这时网卡的配置没有生效,运行/etc/rc.d/init.d/network restart命令我们刚才做的设置才生效

Note:

-这种方法是最底层的修改方法

-在linux中,所有设备都是文件

-Tracert +”ip” 可以查看,访问所经过的路由器

.rpm包.samba配置13.1 RPM包

概述

一种用于互联网下载包的打包及安装工具,它包含在某些linux分发版中。它生成具有.RPM扩展名的文件。RPM是Redhat Package Manager(Redhat软件包管理工具)的缩写。这一文件格式虽然打上了Redhat的标志,但是其原始设计理念是开放式的,现在包括OpenLinux、S.u.S.E.以及Turbo Linux等Linux的分发版本都有采用。可以算是工人的行业标准了

RPM包的名称格式

apache-1.3.23-11.i386.rpm

-“apache”:软件名称

-“1.3.23-11”:软件的版本号,主版本和此版本

-“i386”:是软件所运行的硬件平台

-“rpm”:文件扩展名,代表RPM包

RPM常用命令

-rpm ‐qa:查询所安装的所有rpm软件包

-rpm ‐qa | more

-rpm ‐qa | grep X

-rpm ‐q软件包名:查询软件包是否安装

-rpm ‐q xinetd

-rpm ‐q foo

-rpm ‐qi软件包名:查询软件包信息

-rpm ‐qi file

-rpm ‐ql软件包名:查询软件包中的文件

-rpm ‐ql file

-rpm ‐ql jdk

-rpm ‐qf文件全路径名:查询文件所属的软件包

-rpm ‐qf /etc/passwd

-rpm ‐qf/root/install.log

-rpm ‐qp包文件名:查询包的信息对这个软件包的介绍

-rpm ‐qpjdk-1_5_0-linux-i586.rpm

-rpm ‐qpijdk-1_5_0-linux-i586.rpm

-rpm ‐qpljdk-1_5_0-linux-i586.rpm

安装RPM包

rpm‐ivh RPM包全路径名称:安装包到当前系统

-i=install,安装

-v=verbose,提示,即有提示信息

-h=hash,进度条

删除RPM包

rpm‐e RPM包的名称

【案例】rpm ‐e jdk

如果其它软件包依赖于您要卸载的软件包,卸载时则会产生错误信息,如:

【案例】rpm ‐e foo

removing thesepackages would break dependencies:foo is neededby bar-1.0-1

若让RPM忽略这个错误继续卸载,请使用‐‐nodeps命令行选项

【案例】rpm ‐e ‐‐nodeps foo

升级RPM包

rpm‐U RPM包全路径名

【案例】rpm ‐U cvs-1.11.2-10.i386.rpm

13.2 samba配置

什么是samba

这些年来,windows与linux操作系统各自拥有自己的用户群和市场。然而在一般公司或学校里,可能同时有windows和linux主机,windows主机彼此之间可以利用“网上邻居”来访问共享资源。NFS也能使linux主机之间实现资源访问。而samba服务软件能够使windows与linux之间实现资源共享

SMB通信协议采用的是C/S结构,所以SAMBA软件可分阶段客户端及服务端两部分。通过执行samba客户端程序,linux主机使可使用网络上的windows主机所共享的资源。而在linux主机上安装samba服务器,则可以使windows主机访问samba服务器共享的资源

samba安装

samba的安装步骤

-看看是否已经安装了samba

-rpm ‐q samba

-如果有的话,就先卸载

-rpm ‐e ‐‐nodepssamba

-把安装文件挂载到linux下

-samba-common-2.2.7a-7.9.0.i386.rpm

-samba-client-2.2.7a-7.9.0.i386.rpm

-samba-2.2.7a-7.9.0.i386.rpm

-拷贝samba的rpm包到/home,准备安装

-开始安装

-rpm ‐ivh samba-common-2.2.7a-7.9.0.i386.rpm

-创建一个用户youyou

-useradd youyou

-passwd youyou

-给youyou设置samba密码

-cat/etc/passwd | mksmbpasswd.sh > /etc/samba/smbpasswd

-smbpasswdyouyou,设置密码

-启动samba服务器,测试

-service smbstart,启动

-service smbstop,停止

-service smbrestart,重启

samba配置

共享资源的基本配置 /etc/samba/smb.conf

-comment:针对共享资源所做的说明文字。默认值为空字符串

【案例】comment=dir for todayhero:共享这个目录是为了todayhero这个用户

-path:若共享的资源是目录,是指定该目录的位置

【案例】path=/tmp:共享tmp这个目录

-guest ok:是否允许用户不使用账号和密码访问此资源

【案例】guest ok=yes:允许用户不使用账号和密码访问此资源

【案例】guest ok=no:不允许用户不使用账号和密码访问此资源

-hosts allow:设置连接主机的地址

【案例】hosts allow=192.168.2.1 server.abc.com:允许来自192.168.2.1 或server.abc.com

-hosts deny:设置禁止连接的主机地址

【案例】hosts deny=192.168.2.1:不允许192.168.2.1的主机访问samba服务器的资源

-read only:用于设置共享的资源是否为可读

【案例】read only=yes:允许只读

【案例】read only=no:不仅仅只读,也就是说可以写入

3,用windows上访问linux的共享目录

回到windows,打开“网络”(我用的是win7以前这个东西叫网上邻居),在地址栏输入\\linux ip 比如,\\192.168.100.13,根本找不到?!

有搜索了老半天,好在这个问题还是很普遍的,

关闭linux的防火墙:#service iptables stop。

终于可以找到linux了……

.crontab详解14.1概述

任务调度:是指系统在某个时间执行的特定的命令或程序

任务调度分类:

-系统工作:有些重要的工作必须周而复始地执行,如病毒扫描等

-个别用户工作:个别用户可能希望执行某些程序

任务调度命令

设置任务调度文件:/etc/crontab

设置个人任务调度,执行crontab ‐e命令,接着输入任务到调度文件

【案例】5 * * * * ls ‐l /etc/ > /tmp/to.txt,意思说每小时的第五分钟执行ls命令

调度文件的规则

字段名称

说明

范围

分钟

每小时中的第几分钟执行

0-59

小时

每天的第几个小时执行

0-23

日期

每月的第几天执行

1-31

月历

每年的第几个月执行

1-12

星期

每周的第几天执行

0-6

使用任务调度

-设置任务

-crontab ‐e

-每隔一定时间去执行date> /home/mydate2

-希望每天凌晨2:00去执行 date >>/home/mydate2,可以在crontab ‐e中加入:0 2 * * * date >> /home/mydate2

-希望每分钟去执行:在crontab‐e中加入:* * * * * date>> /home/mydate2

-怎样去调度多个任务

-在crontab ‐e中直接写多个命令(不推荐)

-可以把所有的任务,写入到一个可执行文件(shell编程)

-终止任务调度

-crontab ‐r:终止任务调度

-crontab ‐l:列出当前有哪些任务调度

进程的介绍和管理15.1概述

-在linux 中,每个执行的程序都称为一个进程,每一个进程都分配一个ID号

-每一个进程,都会对应一个父进程,而这个父进程可以复制多个子进程,例如www服务器

-每个进程都可能以两种方式存在的,前台与后台。所谓前台进程就是用户目前的屏幕上可以进行操作的,后台进程则是实际在操作,但由于屏幕上无法看到的进程,通常使用后台方式执行

-一般系统的服务都是以后台进程的方式存在,而且都会常驻在系统中,直到关机才结束

-进程与线程

-进程:就是正在执行的程序

-线程

-轻量级的进程

-进程有独立的地址空间,线程没有

-线程不能独立存在,它是由进程创建

-相对讲,线程耗费的CPU和内存要小于进程

进程的管理

ps命令是用来查看目前系统中,有哪些正在执行,以及它们执行的情况,可以不加任何参数,显示详细的进程信息 (鸟哥linux第二版 p344n)

-ps ‐a:显示当前终端的所有进程信息

-ps ‐u:以用户的格式显示进程信息

-ps ‐x:显示后台进程运行的参数

ps显示的信息选项:

字段

说明

PID

进程识别号

TTY

终端机号

TIME

此进程所消CPU时间

CMD

正在执行的命令或进程名

终止进程kill/killall

若是某个进程执行一半需要停止时,或是已消了很大的系统资源时,此时可以考虑停止该进程,使用kill命令来完成此项任务

终止某个进程:kill 进程号

【案例】kill 16251:终止进程号为16251的进程

【案例】kill -9 16251:因为有些进程会捕捉某些信号,如果直接不能结束进程可以用“-9”传送信息

killall:杀死同名的所有进程

动态监控进程

top命令与ps命令很相似。它们都用来显示正在执行的进程。top与ps最大的不同之处,在于top在执行一段时间可以更新正在运行的进程

-监视特定用户

-top:输入此命令,按回车键,查看执行的进程

-u:然后输入“u”回车,再输入用户名,即可

-终止指定的用户

-top:输入此命令,按回车键,查看执行的进程

-k:然后输入“k”回车,再输入要结束的进程ID号

-指定系统状态更新的时间

-top ‐d 10:指定系统更新进程的时间为10秒

top显示选项解释

-1:52,表示系统启动了多久

-1 user,用户数

-load average:0.00 0.00 0.00,当前系统负载情况,一般来说,参数越小,系统运行的越轻松,当平均数>0.6时,系统就很紧张了

-38 processes,进程数

-0 zombie,僵尸进程数,相当于这个进程没有用了,还占用资源,比如父进程来不及收回子进程

-CPU states:99.3% idle,闲置的CPU

-Mem,内存

-Swap,类似于虚拟内存

设置系统时间

-date命令:显示系统的时间,可以在直接输入“date”命令来查看系统的时间

-date+%y/%m/%d

-2005/06/23

-date +%H:%M

-17:25

-利用date命令来更改系统的时间

-dateMMDDHHMMCCYY.SS:月月日日时时分分年年.秒秒

-查看月历

-cal 3 2002:查看2002年3月的月历

-查看年历

-cal 2008:查看2008的年历

计算器

-bc命令调出计算器

-scale=3为输出小数的位数,linux计算器,默认输出的是为整数.

-quit 退出计算器

监控网络状态16.1几个监控命令

显示网络统计信息的命令netstat

此命令用来显示整个系统目前的网络情况。例如目前的连接、数据包传递数据、或是路由表内容,此命令直接输入即可使用

-netstat ‐anp

-an,按一定顺序排列输出

-p,表示显示哪个进程在调用

检测主机连接命令ping

是一种网络检测工具,它主要是用检测远程主机是否正常,或是两部主机间的介质是否为断、网线是否脱落或网卡故障

-ping 对方ip地址

显示数据包经过历程命令traceroute

此命令可以直接输入使用,用来检测数据包在网络上传输的过程,从本机到远程的主机完整路径,帮助管理员解决问题

显示路由表route

所谓路由是指将数据由来源网络送往目的网络的操作。在大型网络中,路由是非常复杂的,因为数据包在抵目的地时,可能经过的节点有很多,路由表是存储在路由器或一些其他链接设置上的窗体。其中记录着了到指定目的的网络路径,以及这些路径的相关数值

此命令可以直接输入使用,来查看本机路由的情况

mysql安装.配置.使用17.1概述

mysql数据库在linux下可以充分发挥威力,mysql数据库越来越受到软件公司的青睐,为什么呢?

免费、跨平台、轻、支持多并发

在北京很多软件公司属于创业型的中、小公司,从节约成本的角度考虑,mysql特别适合中、小项目

17.2 mysql安装

-创建mysql组

-useradd mysql

-创建mysql用户,并放入到mysql组中

-useradd -g mysql mysql

-进入到mysql文件夹

-初始化数据库

-scripts/mysql_install_db‐user=mysql

-修改文件的所有者

-chown ‐R root .

-修改date文件夹的所有者

-chown ‐R mysql date

-改变用户组

-chgrp ‐R mysql .

-启动mysql

-bin/mysqld_safe–user=mysql &

-&表示以后台的方式启动

-检查一下进程,netstat ‐anp,查看监听端口是3306的是不是打开了

-如何进入mysql

-cd bin

-./mysql ‐u root‐p 回车

Notes:如果希望在任何一个目录下都可以进入mysql,则需在用户变量/root/.bash_profile中添加路径

-测试mysql数据库是否可以在linux下正确使用

-建立数据库和表

-加入部分数据

-编写一个ShowUser.java文件,在控制台显示用户

Note:特别注意mysql的驱动要存放的位置,放在jdk的主目录下的/jre/lib/ext/

备份与恢复

备份:mysqldump ‐u root‐p密码数据库名 > data.bak

恢复:mysql ‐u root‐p密码数据库名 < data.bak

Note:‐p和密码之间没有空格

ssh安装.配置.使用18.1概述

ssh(secure shell)是一款集远程操作linux和进行文件上传和下载的软件,在软件公司几乎所有的linux程序员都会使用ssh。安全、方便是它最大的特点

linux上默认安装ssh服务,且默认是启动的sshd,监听的端口是22。在windows系统上安装SSH客户端,集成了secureCRT与FTP的作用

补充linux重要内容linux启动过程分析

runlevel命令,可以查看当前的运行级别

20.1 linux启动过程

-BIOS自检

-启动GRUB/LILO

-运行linux内核并检测硬件

-运行系统的第一个进程init

-init读取系统引导配置文件/etc/inittab中的信息进行初始化

-/etc/rc.d/rc.sysinit系统初始化脚本

-/etc/rc.d/rcX.d/[KS] * -根据运行级别X配置服务

-终止以“K”开头的服务

-启动以“S”开头的服务

-/etc/rc.d/rc.local执行本地特殊配置

-其他特殊服务

java网络编程

linux下网络编程是linux最让程序员着迷的地方,我们看看如何在linux进行网络编程。最终大家可以在这个基础上扩展为myQQ的程序,并且会使用到mysql数据库

你将学习到:

-如何使用java进行socket编程

-如何在java中对mysql数据库操作

-windows和linux网络通讯

-了解什么是网络服务这个晦涩的概念

linux系统作为服务端,代码如下:

windows作为客户端,代码如下:

再发展下来才有了:大霞美的花卉基地和清源山的花博园。

linux基础

相关文章:

你感兴趣的文章:

标签云: