??xml version="1.0" encoding="utf-8" standalone="yes"?>
]]>
final 用于声明属性,Ҏ和类Q分别表C属性不可变Q方法不可覆盖,cM可ѝfinally是异常处理语句结构的一部分Q表CL执行。finalize?Objectcȝ一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时的其他资源回Ӟ例如关闭文g{?
W二QAnonymous Inner Class (匿名内部c? 是否可以extends(l承)其它c,是否可以implements(实现)interface(接口)?
可以l承其他cL完成其他接口Q在swing~程中常用此方式。
W三QStatic Nested Class ?Inner Class的不同,说得多好(面试题有的很W统)?
Static Nested Class是被声明为静态(staticQ的内部c,它可以不依赖于外部类实例被实例化。而通常的内部类需要在外部cd例化后才能实例化。
W四Q?amp;?amp;&的区别?
&是位q算W,表示按位与运,&&是逻辑q算W,表示逻辑与(andQ?
W五QHashMap和Hashtable的区别?
HashMap是Hashtable的轻量实现Q非U程安全的实玎ͼQ他们都完成了Map接口Q主要区别在于HashMap允许I(nullQ键|keyQ?׃非线E安全,效率上可能高于Hashtable.
W六QCollection ?Collections的区别?
Collection是集合类的上U接口,l承与他的接口主要有Set 和List.Collections是针寚w合类的一个帮助类Q他提供一pd静态方法实现对各种集合的搜索、排序、线E安全化{操作。
W七Q什么时候用assert?
1.4新增关键字(语法Q,用于试boolean表达式状态,可用于调试程序。用方?assert Q表C如果表辑ּ为真QtrueQ?则下面的语句执行Q否则抛出AssertionError。另外的使用方式assert < boolean表达?gt;:Q表C如果表辑ּ为真Q后面的表达式忽略,否则后面表达式的值用于AssertionError的构建参数。注意编译时要增?source 1.4 参数Q否则报错。]q行时要增加 –ea参数Q否则assert行被忽略
W八QGC是什? Z么要有GC?
GC是垃圾收集的意思(Gabage CollectionQ?内存处理是编Eh员容易出现问题的地方Q忘记或者错误的内存回收会导致程序或pȝ的不E_甚至崩溃QJava提供的GC功能可以自动监测对象是否过作用域从而达到自动回收内存的目的QJava语言没有提供释放已分配内存的昄操作Ҏ?
W九QString s = new String("xyz");创徏了几个String Object?
两个
W十QMath.round(11.5){於多少? Math.round(-11.5){於多少?
Math.round(11.5)==12Math.round(-11.5)==-11roundҎq回与参数最接近的长整数Q参数加1/2后求其floor.
W十一Qshort s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?
short s1 = 1; s1 = s1 + 1; Qs1+1q算l果是int型,需要强制{换类型)short s1 = 1; s1 += 1;Q可以正编译)
W十二,sleep() ?wait() 有什么区?
sleep是线E类QThreadQ的ҎQ导致此U程暂停执行指定旉Q给执行Zl其他线E,但是监控状态依然保持,到时后会自动恢复。调?sleep不会释放对象锁。wait是ObjectcȝҎQ对此对象调用waitҎD本线E放弃对象锁Q进入等待此对象的等待锁定池Q只有针Ҏ对象发出notifyҎQ或notifyAllQ后本线E才q入对象锁定池准备获得对象锁q入q行状态。
W十三,Java有没有goto?
没有 很十三的问题Q如果哪个面试的问到q个问题Q我劝你q是别进q家公司?
W十四,数组有没有length()q个Ҏ? String有没有length()q个ҎQ?
数组没有length()q个ҎQ有length的属性?
String有有length()q个Ҏ?
W十五,Overload和Override的区别。Overloaded的方法是否可以改变返回值的cd?
Ҏ的重写Overriding和重载Overloading是Java多态性的不同表现。重写Overriding是父cM子类之间多态性的一U表玎ͼ 重蝲Overloading是一个类中多态性的一U表现。如果在子类中定义某Ҏ与其父类有相同的名称和参敎ͼ我们说该Ҏ被重?(Overriding)。子cȝ对象使用q个ҎӞ调用子cM的定义,对它而言Q父cM的定义如同被“屏蔽”了。如果在一个类中定义了多个同名的方法,它们或有不同的参C数或有不同的参数cdQ则UCؓҎ的重?Overloading)。Overloaded的方法是可以改变q回值的cd?
W十六,Set里的元素是不能重复的Q那么用什么方法来区分重复与否? 是用==q是equals()? 它们有何区别?
Set里的元素是不能重复的Q那么用iterator()Ҏ来区分重复与否。equals()是判M个Set是否相等?
equals()?=Ҏ军_引用值是否指向同一对象equals()在类中被覆盖Qؓ的是当两个分ȝ对象的内容和cd盔R的话Q返回真倹{?
W十七,l我一个你最常见到的runtime exception?
参考如下:
ArithmeticException,
ArrayStoreException,
BufferOverflowException,
BufferUnderflowException,
CannotRedoException,
CannotUndoException,
ClassCastException,
CMMException,
ConcurrentModificationException,
DOMException,
EmptyStackException,
IllegalArgumentException,
IllegalMonitorStateException,
IllegalPathStateException,
IllegalStateException,
ImagingOpException,
IndexOutOfBoundsException,
MissingResourceException,
NegativeArraySizeException,
NoSuchElementException,
NullPointerException,
ProfileDataException,
ProviderException,
RasterFormatException,
SecurityException,
SystemException,
UndeclaredThrowableException,
UnmodifiableSetException,
UnsupportedOperationException
W十八,error和exception有什么区?
error 表示恢复不是不可能但很困隄情况下的一U严重问题。比如说内存溢出。不可能指望E序能处理这L情况?
exception 表示一U设计或实现问题。也是_它表C如果程序运行正常,从不会发生的情况?
W十九,List, Set, Map是否l承自Collection接口?
ListQSet?
Map不是
W二十,abstract class和interface有什么区?
声明Ҏ的存在而不d现它的类被叫做抽象类Qabstract classQ,它用于要创徏一个体现某些基本行为的c,qؓ该类声明ҎQ但不能在该cM实现该类的情c不能创建abstract cȝ实例。然而可以创Z个变量,其类型是一个抽象类Qƈ让它指向具体子类的一个实例。不能有抽象构造函数或抽象静态方法。Abstract cȝ子类为它们父cM的所有抽象方法提供实玎ͼ否则它们也是抽象cMؓ。取而代之,在子cM实现该方法。知道其行ؓ的其它类可以在类中实现这些方法?
接口QinterfaceQ是抽象cȝ变体。在接口中,所有方法都是抽象的。多l承性可通过实现q样的接口而获得。接口中的所有方法都是抽象的Q没有一?有程序体。接口只可以定义static final成员变量。接口的实现与子cȝ|除了该实现类不能从接口定义中l承行ؓ。当cd现特D接口时Q它定义Q即程序体l予Q所有这U接口的Ҏ。然后,它可以在实现了该接口的类的Q何对象上调用接口的方法。由于有抽象c,它允怋用接口名作ؓ引用变量的类型。通常的动态联~将生效。引用可以{换到接口cd或从接口cd转换Qinstanceof q算W可以用来决定某对象的类是否实现了接口?
W二十一Qabstract的method是否可同时是static,是否可同时是nativeQ是否可同时是synchronized?
都不?
W二十二Q接口是否可l承接口? 抽象cL否可实现(implements)接口? 抽象cL否可l承实体c?concrete class)?
接口可以l承接口。抽象类可以实现(implements)接口Q抽象类是否可承实体类Q但前提是实体类必须有明的构造函数?
W二十三Q启动一个线E是用run()q是start()?
启动一个线E是调用start()ҎQɾU程所代表的虚拟处理机处于可运行状态,q意味着它可以由JVM调度q执行。这q不意味着U程׃立即q行。run()Ҏ可以产生必须退出的标志来停止一个线E?
W二十四Q构造器Constructor是否可被override?
构造器Constructor不能被承,因此不能重写OverridingQ但可以被重载Overloading?
W二十五Q是否可以承Stringc?
StringcLfinalcL不可以ѝ?
W二十六Q当一个线E进入一个对象的一个synchronizedҎ后,其它U程是否可进入此对象的其它方?
不能Q一个对象的一个synchronizedҎ只能׃个线E访问?
W二十七Qtry {}里有一个return语句Q那么紧跟在q个try后的finally {}里的code会不会被执行Q什么时候被执行Q在return前还是后?
会执行,在return前执行?
W二十八Q编E题: 用最有效率的Ҏ出2乘以8{於?
有C背景的程序员特别喜欢问这U问题?
2 < < 3
W二十九Q两个对象值相?x.equals(y) == true)Q但却可有不同的hash codeQ这句话对不?
不对Q有相同的hash code?
W三十,当一个对象被当作参数传递到一个方法后Q此Ҏ可改变这个对象的属性,q可q回变化后的l果Q那么这里到底是g递还是引用传?
是g递。Java ~程语言只由g递参数。当一个对象实例作Z个参数被传递到Ҏ中时Q参数的值就是对该对象的引用。对象的内容可以在被调用的方法中改变Q但对象的引用是永远不会改变的?
W三十一Qswtich是否能作用在byte上,是否能作用在long上,是否能作用在String?
switchQexpr1Q中Qexpr1是一个整数表辑ּ。因此传递给 switch ?case 语句的参数应该是 int?short?char 或?byte。long,string 都不能作用于swtich?
W三十二Q编E题: 写一个Singleton出来?
Singleton模式主要作用是保证在Java应用E序中,一个类Class只有一个实例存在?
一般Singleton模式通常有几U种形式:
W一UŞ? 定义一个类Q它的构造函Cؓprivate的,它有一个static的private的该cd量,在类初始化时实例话,通过一个public的getInstanceҎ获取对它的引?l而调用其中的Ҏ?
public class Singleton {
private Singleton(){}
//在自己内部定义自׃个实例,是不是很奇怪?
//注意q是private 只供内部调用
private static Singleton instance = new Singleton();
//q里提供了一个供外部讉K本class的静态方法,可以直接讉K
public static Singleton getInstance() {
return instance;
}
}
W二UŞ?
public class Singleton {
private static Singleton instance = null;
public static synchronized Singleton getInstance() {
//q个Ҏ比上面有所改进Q不用每ơ都q行生成对象Q只是第一ơ
//使用时生成实例,提高了效率!
if (instance==null)
instanceQnew Singleton();
return instance; }
}
其他形式:
定义一个类Q它的构造函Cؓprivate的,所有方法ؓstatic的?
一般认为第一UŞ式要更加安全?
其中也存在一些问题,下面补充一下.希望大家l箋补充
1.最好介l一下final修饰变量的情形(分开说明基本cd变量和引用类型变量)?
2.不知道如何描q比较好Q匿名内部类本n是一个实C特定接口或承了其他cȝcR?
3.非静态类不能有static的方法。参考一下java collections framework的代码,q能说出很多东西来?
4.&既是位运符Q也是逻辑操作W?
&?amp;&都是逻辑q算W,它们的区别是Q?amp;&q行短\计算?
6.可以补充一下,参考文档?
11.说一下具体的原因可能更好?
13.java有gotoq个keywordQ不q还没有使用?
15.overload和多态没有Q何关pR多态是面向对象的基本特征,是和l承、overriding相关的。原来以为把overload当作多态的一U是从C++来的Q后来翻了基本c++的经典的?也强调多态只是和l承,虚函?overriding相关,所以不知道q个错误思想从哪来的?
16.public interface Set <E>extends Collection <E>一个不包含重复元素?collection。更切地讲Qset 不包含满?e1.equals(e2) 的元素对 e1 ?e2Qƈ且最多包含一?null 元素。正如其名称所暗示的,此接口模仿了数学上的 set 抽象?
看文档就是了.
22."抽象cL否可l承实体c,但前提是实体cdL明确的构造函数?什么意?谁规定的?
27.q个比较复杂,例如
public class Main {
public static void main(String[] args) {
System.out.println(test());
}
public static boolean test() {
boolean b = false;
try {
return b = 4 > 3;
} finally {
System.out.println(b);
//return false;
}
}
}
q个例子中可以看?return后面的表辑ּ已经计算?感觉return语句q里被挂起了,如果finally中没有return,q个returnp?
如果finally也有return,那么是finally中的returnq回?
29.C不守规矩的程序员谁也没办?
31.q有枚D?
32.注释有问?
如需转蝲Q请注明出处Q?/font>http://bbs.iusesvn.com/thread-3068-1-1.html
此文讲述SVN如何镜像服务?/span>Q注意是单向镜像。众所周知Q?/font>SVN有自已的镜像命osvnsync(svn1.4以及以上版本Ҏ?/font>),但是部v与维护确是繁琐至极,令h望而却步。我们来看一个简单的svnsync例子Q?/font>
?/font>SVN服务器: http://mastersvn/project1
svnsync镜像SVN服务器上的部|Ԍhttp://backupsvn/project1
W一步:建立仓库
cd /home/svn
svnadmin create –fs-type fsfs /home/svn/project1
chmod 777 –R project1
W二步:镜像初始?/font>
svnsync init http://backupsvn/project1 http://mastersvn/project1
W三步:更改配置文g
cd /home/svn/project1/hooks
cp pre-revprop-change.tmpl pre-revprop-change
vi pre-revprop-change
注销所有语句,在语句前加入#卛_Q退Z?/font>
W四步:同步
svnsync sync http://backupsvn/project1 --username username --password password
已提交版?/font> 9?/font>
复制版本 9 ?span class="t_tag" onclick="tagshow(event)" href="tag.php?name=%E5%B1%9E%E6%80%A7">属?/span>?/font>
已提交版?/font> 10?/font>
复制版本 10 的属?/font>
……………
但是在实际运用中Q经怼发生SVN库被lock的情?/font>
svnsync: Couldn't get lock on destination repos after 10 attempts
q不得不让我们感觉头痛地手动使用改命令解?/font>
svn propdel svn:sync-lock --revprop -r0 http://backupsvn/project1
写到q里Q大家不由对svnsync有了个初步的认识了吧Q就一个字Q烦Q!Q而且同步速度很慢Q!Q?/font>
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
接下来是此文的重炚w分:
SVN新的镜像备䆾ҎQ?/font>ssh + rsync + crontab(d计划))
什么是SSH?
SSH 是更灉|、更安全?/font> telnet ?/font> rlogin 替代品。它?span class="t_tag" onclick="tagshow(event)" href="tag.php?name=%E5%BC%80%E5%8F%91">开?/span>目中得到广泛用,以提?span class="t_tag" onclick="tagshow(event)" href="tag.php?name=%E8%AE%BF%E9%97%AE">讉K控制和安全的数据传输?/font>
什么是rysnc?
rsync是类unixpȝ下的数据镜像备䆾工具Q从软g的命名上可以看出来?/font>——remote sync。它的特性如下:
可以镜像保存整个目录树和文gpȝ?/font>
可以很容易做C持原来文件的权限、时间、Y链接等{?/font>
无须Ҏ权限卛_安装?/font>
优化的流E,文g传输效率高?/font>
可以使用rcp?/font>ssh{方式来传输文gQ当然也可以通过直接?/font>socketq接?/font>
支持匿名传输Q以方便q行|站镜象?/font>
什么是crontab?
Crontab?/font>Linux操作pȝ下的一个命令,可以用来Ҏ旉、日期、月份、星期的l合来调度对重复d的执行的守护q程?/font>(cMwindows下的d计划)
Ҏ拓扑图:Q请看附Ӟ
?/font>SVN服务?span class="t_tag" onclick="tagshow(event)" href="tag.php?name=%E7%8E%AF%E5%A2%83">环境Q?/font>
SVN仓库根目录: /home/svn (project1,project2,project3三个仓库)
SVN服务?/font>IPQ?/font> 192.168.100.80
镜像SVN服务器环境:
SVN仓库根目录:/home/svn Q无仓库Q无需建立Q镜像时会直接复制过来ƈ保持文g属性)
SVN服务?/font>IPQ?/font> 192.168.100.81
#?/font>SVN服务器安装部分:
Q?/font>1Q?/font>
SVN安装部分Q略Q?/font>
Q?/font>2Q?/font>
安装rsync部分
rpm -qa | grep rsync (所有系l是否有安装q?/font>rsync)
rpm -e rsyncxxx (删除以前安装q的rsync)
wget http://samba.anu.edu.au/ftp/rsync/rsync-3.0.4.tar.gz (下蝲rsync源码安装?/font>)
tar zxvf rsync-3.0.4.tar.gz (解压)
cd rsync-3.0.4
./install.sh (安装)
接下来我们就可以输入rsync --version命o来测试下是否安装成功了?/font>
rsync
version 3.0.3
protocol version 30
Copyright (C) 1996-2008 by Andrew Tridgell, Wayne Davison, and others.
Web site: http://rsync.samba.org/
Capabilities:
64-bit files, 64-bit inums, 32-bit timestamps, 64-bit long ints,
socketpairs, hardlinks, symlinks, IPv6, batchfiles, inplace,
append, ACLs, xattrs, iconv, no symtimes
rsync comes with ABSOLUTELY NO WARRANTY.
This is free software, and you
are welcome to redistribute it under certain conditions.
See the GNU
General Public Licence for details.
(3) 开?/font>rsync服务器端
/usr/local/bin/rsync --daemon (开?/font>rsync服务)
vi /etc/rc.d/rc.local
在末֊?/font>/usr/local/bin/rsync --daemon (目的是让服务器每ơ重启后都能自动q行此进E?/font>)
#镜像SVN服务器安装部分:
Q?/font>1Q?/font>SVN安装部分Q略Q?/font>
Q?/font>2Q?/font>安装rsync部分
rpm -qa | grep rsync (所有系l是否有安装q?/font>rsync)
rpm -e rsyncxxx (删除以前安装q的rsync)
wget http://samba.anu.edu.au/ftp/rsync/rsync-3.0.4.tar.gz (下蝲rsync源码安装?/font>)
tar zxvf rsync-3.0.4.tar.gz (解压)
cd rsync-3.0.4
./install.sh (安装)
接下来我们就可以输入rsync --version命o来测试下是否安装成功了?/font>
接下来我们的配置完成了Q让我们用命里那个测试下?/font>
同步命oQ?/font>
rsync -vzrtopgu --progress --delete root@192.168.100.80:/home/svn /home/
输入用户?/font>root
输入root?span class="t_tag" onclick="tagshow(event)" href="tag.php?name=%E5%AF%86%E7%A0%81">密码?/font>
65309 100%
224.57kB/s
0:00:00 (xfer#507, to-check=2187/23106)
svn/project1/db/revs/202
29655 100%
99.86kB/s
0:00:00 (xfer#508, to-check=2186/23106)
svn/project1/db/revs/203
7242 100%
23.19kB/s
0:00:00 (xfer#509, to-check=2185/23106)
sent 15928 bytes
received 521860019 bytes
4404016.43 bytes/sec
total size is 12240235825
speedup is 23.45
传输完成Q这ơ镜像过E就l束了?/font>
让我们看看所使用的参敎ͼ
v 复杂的输Z?/font>
z 压羃模式, 当资料在传送到目的端进行档案压~?/font>.
r 复制所有下面的资料(透过)
t 保留旉?/font>
o 保留档案所有?/font>(root only)
p保留档案权限
g 保留档案组
u更新修改q的文g
--progress 昄传送的q度
--delete 删除传送断已经不存?/font>,而目的端存在的档?/font>
root@192.168.100.80:/home/svn /home/
?/font>root用户讉K192.168.100.80?/font>/home/svn目录Q然后同步到本机?/font>/home/目录下,注意格式Q那么镜?/font>SVN服务器就会把?/font>SVN服务器上?/font>/home目录?/font>svn文gҎ个复制到镜像SVN服务器上?/font>/home下,q保存原属性不变?/font>
###注意:Z么?/font>root的用户呢Q因为可以确保保证同步过来的文g可以保证档案的具体属性,q是我们比较兛_的问题,但是root的用h有的权限太大了,每次都需要输?/font>root的密码,一斚wq是非常危险的,一斚w比较J琐?/font>
那么我们首先惛_的不需要输?span class="t_tag" onclick="tagshow(event)" href="tag.php?name=%E7%94%A8%E6%88%B7%E5%90%8D">用户?/span>和密码就可以镜像和传输文Ӟ那么必须让两?/font>SVN服务器互怿?/font>,那么我们需要采?/font>sshU钥和公钥加密技术?/font>
?/font>SVN服务器:
ssh-keygen –d
Enter file in which to save the key (/home/root/.ssh/id_dsa): Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /home/root/.ssh/id_dsa.Your public key has been saved in /home/root/.ssh/id_dsa.pub.The key fingerprint is:32:21:e1:3b:7d:6e:de:4b:39:da:af:38:fe:90:40:61 root@svnserver.com
cd .ssh
id_dsa ------------ U钥文g
id_dsa.pub ------------ 公钥文g
cp id_dsa.pub authorized_keys2 (复制一个可以被root识别和读取的公钥文g)
chmod 600 authorized_keys2 (因安全因为给?/font>600权限)
cp id_dsa.pub svnserver.pub (再做一份公钥的副本)
惛_法把q个公钥的副本移动到镜像SVN服务器上面?/font>
cat mirrorsvnserver.pub >> authorized_keys2 (把复制过来的镜像SVN服务器上的公钥导入到?/font>SVN服务器的公钥文g?/font>)
镜像SVN服务器:
ssh-keygen –d
Enter file in which to save the key (/home/root/.ssh/id_dsa): Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /home/root/.ssh/id_dsa.Your public key has been saved in /home/root/.ssh/id_dsa.pub.The key fingerprint is:32:21:e1:3b:7d:6e:de:4b:39:da:af:38:fe:90:40:61 root@mirrorsvnserver.com
cd .ssh
id_dsa ------------ U钥文g
id_dsa.pub ------------ 公钥文g
cp id_dsa.pub authorized_keys2 (复制一个可以被root识别和读取的公钥文g)
chmod 600 authorized_keys2 (因安全因为给?/font>600权限)
cp id_dsa.pub mirrorsvnserver.pub (再做一份公钥的副本)
惛_法把q个公钥的副本移动到?/font>SVN服务器上面?/font>
cat svnserver.pub >> authorized_keys2 (把复制过来的?/font>SVN服务器上的公钥导入到镜像SVN服务器的公钥文g?/font>)
让我们里验证公钥文g中的内容Q?/font>
cat /root/.ssh/authorized_keys2
ssh-dss AAAAB3NzaC1kc3MAAACBAL9iAG+VZkXunZ5KzTivat1deDAQFKdrGY5P2rxRI+QeKClNgfukUNwQmU+a5FqfNsLKlWhGbIfFI1k00Zkc7nwMdG2dtcnWw7oUqPCGizMcoPLXXQhfOPaFoOkB5UPWNkgJobBPZBjJ7nhKZxzzMiujhOVYLvGNDEWI8x3NAAAAFQCqqtJaMgVyMgDexUKbHIBXsSghYIB5U82gTyGb2c4z4AsmQ5M0ds3YHHVLPHRUEn7DspzlNZ7fYWhKzQYWlhPJftuYTrYIEzuXx8Hl8kg7hCEl4hArAgMMcEtmuQ+3x5SkEht3077qUPdC/YzSk7cFNwQlt6nOeYELCIwhs1CXWQXi9E/XSlqepd+gSlAAhVzWc0MgAAAIAy4qWyaB6DT+XWtq23jrFrYeejJyFBVkNVUbEd3GNTHvwKTYuBa7nlh562g5r0riIrHW+a7WGd6U32RVLnqqIwddcHml4kXnondo0qjW4XijYI7jkHN9oAK5mNWnSCYAnot1nra3QXlh9472/l7kTmznumjsDDjAIa7OFY9w== root@svnserver.com
ssh-dss AAAAB3NzaC1kc3MAAACBAPI3YFCQNBof9xA/Fi1S0U4jmliAg/TaWHnx9suaYb5Xc31jW3+axbNURIBnK7cA53q+qBME1DdddSBOq+I0oUpfjAXkOUl/ACRbSRqA1VOaKdI2AOH9tw4jSK0xSqYjj+ReuUnuVMSTOJTQzt1n6YsLj/kjAAAAFQCHE5NqPCIlr5xVFYOZmGysI+CtKQAAAIAb/gjP0f3Ifx0H2A3XzH9fG4YENLd+gz0l07Mq356+IBuPSYxi4JldxZ7j1OkH9j+7+t8AOSyqNqiOzKXpimo0NLjVsEkpn9RXFmzfHHwRholmauDKIbGLvJlTL0ZkjqH3w0plGmVC6YyxOpM4w7XklIvtq3rDZQE4O247yxgAAAIEA2rd2htKfO9I7F+rBxVgszeGrwCfP5gf8sdz32LDd+E4JxzI/b79Tn1ylILb0vGZhRCbFhoLnDIUMR3Lrr5FqGlTf8O2gsvproA5pLqUpgrkhR/7siycplOddftt553yBJNCBkq+E906AwQ72PNs2uLrbKHyVyD1akrD2/hfA= root@svnmirrorserver.com
q样我们的两?/font>SVN服务器就得到信Q了?/font>
让我们再ơ执行同步命令:
rsync -vzrtopgu --progress --delete root@192.168.100.80:/home/svn /home/
发现了什么?
已经不需要输入用户名和密码了?/font>
最后我们需要设定h物计划了?/font>
crontab –e
*/10 * * * * /usr/local/bin/rsync -vzrtopgu --progress --delete root@192.168.100.80:/home/svn /home/ &
退Z存?/font>
q个例子是每10分钟同步一?/font>,当然我们也可?span class="t_tag" onclick="tagshow(event)" href="tag.php?name=%E8%AE%BE%E7%BD%AE">讄我们惌的时间?/font>
另外一个例子:每小时同步一?/font>
* */1 * * * /usr/local/bin/rsync -vzrtopgu --progress --delete [email=root@192.168.100.80:/home/svn]root@192.168.100.80:/home/svn /home/ &
备注Q?/font>
(1) 所有同步都为增量备份,W者不大家都采用增量备份对SVNq行备䆾Q这有可能导?/font>SVN库日后不可用Q但W者这里将有不下50?/font>SVN库,同步几月都没发生M问题Q都能正常被使用。但是ؓ了}慎v见,希望大家再做一个定期全备䆾Q徏议每周一ơ。如有用户因此丢失,W者将不负M责Q?/font>
(2) 此方法适应Windows上用,rsyncE序名称?/font>cwRsync
(3) rsync有二U配|方式:一U是ssh,scp,stock{协议直接传输,无需修改配置文gQ笔者用法)Q第二种是修?/font>rsync配置文gQ映\径和指定密码Q支持匿名)
(4) ssh + rsync + crontab只是复制文g而已Q无需依赖apache?/font>subversionE序
最单的做法是在代码中嵌入许多的打印语句,但是q样打印语句会充斥代码的MQ显然不是一个好Ҏ。因此,使用成熟的框架例如Log4jQ则会更LzL?
Log4j?br /> Log4j 框架是用 Java 语言~写的标准日志记录框架。作?Jakarta 目的一部分Q它?Apache 软g许可证(Apache Software LicenseQ下分发Q以速度和灵zLؓ中心概念QLog4j 环境是完全可配置的,通过使用Log4jQ我们可以控制日志信息输送的目的地是控制台、文件、GUIlg、甚x套接口服务器、NT的事件记录器?UNIX Syslog守护q程{;我们也可以控制每一条日志的输出格式Q通过定义每一条日志信息的U别Q我们能够更加细致地控制日志的生成过E?
Log4j׃个重要的部g构成Q记录器QLoggersQ、输出源QAppendersQ和布局QLayoutsQ?/font>
记录器按照布局中指定的格式把日志信息写入一个或多个输出源。输出源可以是控制台、文本文件、XML文g或SocketQ甚臌可以把信息写入到Windows事g日志或通过电子邮g发送。我们可以通过配置文g来部|这些组件?/font>
其实您也可以完全不用配|文Ӟ而是在代码中配置Log4j环境。但是,使用配置文g您的应用E序更加灉|。本文从描述 log4j 体系l构的主要组件着手。然后是描述基本用法和配|的单示例?/font>
定义配置文g
Log4j支持两种配置文g格式Q一U是XML格式的文Ӟ一U是JavaҎ文Ӟ?|。下面我们介l用JavaҎ文件做为配|文件的ҎQ?
一?配置记录器?/font>
Log4j允许E序员定义多个记录器Q每个记录器有自q名字。但有一个记录器叫根记录器,它永q存在,且不能通过名字索或引用Q在配置文g中,可以如下定义根记录器Q?/font>
log4j.rootLogger = [ level ] , appenderName, appenderName, …
Level是记录器的别,它是日志记录的优先Q分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的别。Log4j只用四个别:ERROR、WARN、INFO、DEBUGQ?/font>
DEBUG < INFO < WARN < ERROR < FATAL
双的别比左边的高。如果一条log信息的别,大于{于记录器的U别|那么记录器就会记录它。例如level被设|ؓINFOU别Q那么应用程序中所有的DEBUG的日志信息将不被打印出来。通过在这里定义的U别Q您可以控制到应用程序中相应U别的日志信息的开兟?/font>
appenderName是输出源的名字,它指定日志信息输出到哪个地方。您可以Z个记录器指定多个输出源?/font>
在一些配|文件中Q你可能会看C面的语句Q?/font>
log4j.rootCategory = [ level ] , appenderName, appenderName, …
在早期的Log4j版本中,org.apache.Category实现了记录器的功能,Z提高向后兼容 性,Logger扩展了CategoryQ因此rootCategory和rootLogger是可以互换的Q但最后Category从cd中删除,?此请使用LoggercR?/font>
除了根记录器之外Qlog4j允许E序员定义多个记录器Q每个记录器有自q名字Q?/font>
log4j.logger.loggerName = [ level ] , appenderName, appenderName, …
在Log4J中Logger是具有层ơ关pȝQLog4j支持配置的记录器之间?#8220;父子关系”Q记录器之间 通过名字来表明隶属关p(或家族关p)Q它们有一个共同的根,位于最上层Q其它Logger遵@cM包的层次Q记录器a.b,与记录器a.b.c之间是父 子关p,而记录器a与a.b.c之间是祖先与后代的关pR例如:
static Logger root = Logger.getRootLogger();
static Logger log1 = Logger.getLogger("cc");
static Logger log2 = Logger.getLogger("cc.ejb");
static Logger log3 = Logger.getLogger("cc.ejb.my.TestApp");
log4j.logger.com.foo=WARN
package com.foo;
class Bar{
static Logger log=Logger.getLogger(bar.Class.getName());
.....
}
׃记录器com.foo.Bar 没有指定的别,它从com.fooQ在配置文g中其U别讄成WARNQ?l承U别。ƈ且这h们就能方便的从大量log信息中判断出它们各自的来源。当然了Q这不是性规定的Q实际上Log4j没有对设|记录器的实例名做什?限制Q程序员可以Ҏ自己的喜好随意定义?/font>
二、日志信息输出源Appender
log4j q允许日志记录请求打印到多个输出目的圎ͼ?log4j 的叫法是输出源。一个记录器可以有多个输出源。一条log信息如果可被q个记录器处理,则该记录器会把这条信息送往每个它所拥有的输出源Q以及层ơ结构中 更高U的输出源。例如,根记录器以控制台作ؓ输出源,则所有可被纪录的日志都将臛_打印到控制台?/font>
配置日志信息输出源,其语法ؓQ?/font>
log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4j.appender.appenderName.option1 = value1
…
log4j.appender.appenderName.option = valueN
Log4j提供的appender有以下几U:
h意,可以通过覆盖~省行ؓQ这样就不再附加累积的输出源Q?/font>
log4j.additivity.loggerName=false
注意Q不要把一个输出源附加到多个记录器上,否则会得?#8220;Attempted to append to closed appender named xxx”的信息?/font>
三、配|日志信息的格式Q布局Q,其语法ؓQ?/font>
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1
…
log4j.appender.appenderName.layout.option = valueN
其中QLog4j提供的layout有以下几U:
如果采用了PatternLayout, 则Log4J采用cMC语言中的printf函数的打印格式格式化日志信息Q打印参数如下:
四、例?br /> 下面是一个完整的Log4j配置文gQ这个配|文件指定了两个输出源stdout和R。前 者把日志信息输出到控制台Q后者是一个轮转日志文件。最大的文g?00KBQ当一个日志文件达到最大尺寸时QLog4J会自动把example.log 重命名ؓexample.log.1Q然后重Z个新的example.log文gQ依ơ轮转?/font>
log4j.rootLogger=debug, stdout, R
log4j.appender.stdout=org.apache.log4j.FileAppender
log4j.appender.stdout.File=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%nlog4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.loglog4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=1log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%nlog4j.logger.cc.ejb.my=error,out
log4j.appender.out=org.apache.log4j.ConsoleAppender
log4j.appender.out.layout=org.apache.log4j.PatternLayout
log4j.appender.out.layout.ConversionPattern=%p %t %c - %m%nlog4j.logger.cc.ejb.my.son=debug
log4j.additivity.cc.ejb.my.son=false
在代码中使用Log4j
一、得到记录器
使用Log4jQ第一步就是获取日志记录器Q这个记录器负责控制日志信息。其语法为:
public static Logger getLogger( String name)
通过指定的名字获得记录器Q如果必要的话,则ؓq个名字创徏一个新的记录器。Name一般取本类的名字,比如Q?
static Logger logger = Logger.getLogger ( ServerWithLog4j.class.getName () )
二、读取配|文?
当获得了日志记录器之后,W二步将配置Log4j环境Q其语法为:
//自动快速地使用~省Log4j环境?br />
BasicConfigurator.configure ();
//d使用Java的特性文件编写的配置文g
PropertyConfigurator.configure ( String configFilename);
//dXML形式的配|文?br /> DOMConfigurator.configure ( String filename );
三、插入记录信息(格式化日志信息)
当上两个必要步骤执行完毕Q您可以轻村֜使用不同优先U别的日志记录语句插入到您想记录日志的Q何地方,其语法如下:
Logger.debug ( Object message ) ;
Logger.info ( Object message ) ;
Logger.warn ( Object message ) ;
Logger.error ( Object message ) ;
四、例?/font>
我们通过下面q个单的例子Q来演示在程序如何用Log4jQ您可以修改配置文g以得C同日志信息?/font>
package cc.ejb.my;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import my.son.Foo;
public class TestApp {static Logger logger=Logger.getLogger(TestApp.class.getName());
public static void main(String[] args) {
PropertyConfigurator.configure("log4j.properties");
logger.info("Applcaiton Starts");
logger.warn("Bar Starts");
Bar bar=new Bar();
logger.error("Bar Errors");
bar.doIt();
logger.warn("Bar Exits");
logger.info("Foo Starts");
Foo foo=new Foo();
logger.error("Foo Errors");
foo.doit();
logger.warn("Foo exits ");
logger.info("Applcaition Exits");
}}
class Bar
{
static Logger logger = Logger.getLogger(Bar.class.getName());
public void doIt() {
logger.debug("Did it again!");
}
}package cc.ejb.my.son;
import org.apache.log4j.Logger;
public class Foo {
private Logger log=Logger.getLogger(Foo.class.getName());
public Foo() {
log.info("Foo Initialzie");
}
public void doit()
{
log.debug("Do it in Foo");
}}