- 在线时间
- 63 小时
- 最后登录
- 2019-5-3
- 注册时间
- 2004-5-10
- 听众数
- 443
- 收听数
- 0
- 能力
- -250 分
- 体力
- 10122 点
- 威望
- -12 点
- 阅读权限
- 150
- 积分
- -516
- 相册
- 6
- 日志
- 10
- 记录
- 10
- 帖子
- 2003
- 主题
- 1253
- 精华
- 43
- 分享
- 8
- 好友
- 1292

复兴中华数学头子
TA的每日心情 | 开心 2011-9-26 17:31 |
|---|
签到天数: 3 天 [LV.2]偶尔看看I
- 自我介绍
- 数学中国网站(www.madio.cn)是目前中国最大的数学建模交流社区
群组: 越狱吧 群组: 湖南工业大学数学建模同盟会 群组: 四川农业大学数学建模协会 群组: 重庆交通大学数学建模协会 群组: 中国矿业大学数学建模协会 |
2#
发表于 2004-9-27 14:27
|只看该作者
|
|邮箱已经成功绑定
如何实现自动登录Linux (Runlevel 5)
6 H# Z7 P) u/ M
8 Q9 d3 y# m+ Z1 t0 D; z机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
$ B- U9 n0 h. H5 ~: ]* ?一、linux启动的最后阶段的工作 - B4 X% V2 N* H) L* B
/ E2 H" `, c; C* Y$ A
linux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
: l. E0 y' ]( ^7 ?& Y4 z& i" X( M5 D. i: b
运行xdm启动X window; 8 f9 k# f1 Q* ?& `
运行gdm,进入gnome桌面环境; ) [5 S, i& [6 S$ k# c
运行kdm进入kde桌面环境; $ C. k0 {- P- O( _5 ~4 F0 G/ B" ~
自动登录进入linux; 7 q) W1 L4 L/ g% B6 [
prefdm脚本框架大致如下: 9 h0 a$ p; K4 K9 E# O
3 t5 Q* l' m6 @- x* M6 ~7 U& b
#!/bin/sh
" P+ K* [0 G; V/ ^ l. QPATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin 2 i' Y: Q8 R M6 Q' ~
. /etc/profile.d/lang.sh
8 U& e/ H I6 @" f* f# 第一步:查看是否为自动登录 2 Z. b8 E6 m9 H
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 7 m# k. z7 \6 B# O, B' x: S
if /usr/sbin/autologin; then / G* w3 ~5 V/ b q6 X/ U7 I
exit 0 2 Y8 j* D+ \/ g3 R G9 [& H
fi
* M5 }1 e6 _+ Y3 Ufi
' s- |0 k. C6 C' q9 ]& X: d, j/ F, I2 {" U( @0 B
# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式
: E; o+ f5 K& |, U4 ^- r...... & |; A& e' j" p: f0 C$ g) m* W# [
# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 - X" u# Y& z6 M: W% |
...... $ ]/ s! E& l1 p, w# ]7 `4 o
6 _+ v; k& M7 F4 _. e9 M
- @6 m# x9 {8 r. p( @- ~, [, e7 Q6 p9 k7 U" j3 s# s
! W/ a0 A& j# y. [: Z8 n二、自动登录的实现(autologin的实现) * U; d6 M( r% C
1 U: H% O; J4 z; h! @+ W: R在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。 ( `0 ]' W3 ?- J, e* T$ J0 M1 t
, e* x9 U& A# \: R5 s5 z( }1 N
自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 2 u. f2 L0 k# V
6 I6 I$ S& p* S( U8 I2 E& v
Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。
5 \- } Z6 e! {5 P& z P实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。 5 |0 \: m4 D& ? J- p! F
startx脚本的最基本框架是:
0 j( S1 S5 ~4 s9 t2 S4 f8 N
5 r! d$ I# C7 A) n& R$ i0 Q i3 Da、 寻找.xinitrc,如果没有则使用xinitrc; 0 f* S: ?+ g9 }5 L( z
b、 寻找.xserverrc,如果没有则使用xserverrc; ! O2 g" j5 o- o
c、 根据找到的脚本确定xinit的参数;
$ Y& }& `. L1 J( \
, C9 ?# Z( [- H9 r; f由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录: 3 h2 b; U& X* U; ~. k' ?% l* N" x
+ A& w2 k5 D) u2 B& u( I' F3 W, T7 c
0 y7 Y: N5 `* i' }- j#!/bin/sh 5 Z+ @& Q7 I5 ~6 a/ {( m9 L
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin 5 n/ f: H- ^. E, n$ I: P2 Z* ^
. /etc/profile.d/lang.sh
! f0 p* H% J; u( W# 第一步:查看是否为自动登录
5 f" r8 W/ r- \' e' J7 z#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 4 O* l3 w$ o! Y3 ^
#注释掉上边的条件测试,直接运行startx 2 |9 I+ f7 k, ~0 y5 [. g
if /usr/X11R6/bin/startx; then * D! D* t( \" v# U; S" c% l6 C9 @* L
exit 0
4 B8 D' m, a7 i. ~0 G. K5 ofi % M$ t* E/ L; u
#fi + X! j4 m5 S5 m: M$ M
/ a7 ~+ b) k' h" V! |% s7 U/ }* `) x
1 x. U6 R5 P( h/ ^' T6 f" Q0 ~! I6 ~! T: I
* O5 [2 f! U+ o: n( e9 P
当然,应确保/etc/inittab中的启动级别为5。
+ V# E3 Q: J' R% O/ V6 H9 e
3 Z" K1 H2 {* u9 [6 O$ D重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
& l( l5 [* b# C) P& ^" s! _- U0 V
: l" g+ S& X2 Q/ K n; u1 k三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 6 f8 [8 f5 ~8 `
3 G5 S8 }, \4 d" z: Q3 N观察原来/etc/X11/prefdm脚本的自动登录部分: 3 t) u* U1 `( }8 e9 I) F
* N8 D# f) B; a& W. s
' R2 d X6 _( t' E2 x. g" f! I0 v...... ' q0 D- _' J) m& s- Q
# 第一步:查看是否为自动登录
* y2 B3 r$ ^% Y1 R P$ [if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
0 g. O/ b) P3 O J$ uif /usr/sbin/autologin; then / g P1 b7 [1 W2 ~; H* ]
exit 0
+ Y4 H. ? r2 D$ m5 E0 Mfi % v+ E# R9 ~; d2 K
fi 6 S" K: n( U% `2 @6 Y! g
...... ( }* s, o9 v. Z6 j0 B4 P
" j9 Y! y4 F4 t
+ h: a, B4 X8 y/ v& L- q H: D
% m- I% m8 [, C6 K
8 Z4 E0 L) C' d- \/ R! ?不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
( d5 T& K: b2 z
& C, V9 m( k& J5 K* V3 h. Y# B2 ^1、/etc/sysconfig/autologin配置文件的实现:
% N& q& [( d/ k/ Z- H5 N2 R8 ^5 w' ^$ J( J8 c/ m
/ @' {9 J+ w- t1 J1 R- p
#config for autologin
# T$ M/ \) g D7 W9 EUSER=root
; r9 p/ B* Q, Z. s4 X. }& KEXEC=/usr/X11R6/bin/startx
8 H. C c# K/ j& O说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。 * j, ~% y# Z% L0 w- ^
4 F/ v4 l. {4 ]* C! n$ i
6 n& T6 I5 N! N& |) i
0 \' \" ^' G* T2 b0 I! u
! _. A5 z. I# |* R# c3 y' {+ U5 `2、/usr/sbin/autologin可执行文件的实现: # H! v2 X9 B* b( _2 @
4 e9 h( z% w5 d) C* q" M
! L0 h0 m: t' c3 Q/ D0 }% I5 o
/********************* ( s$ {* a% m- O, W
**** autologin.c ****
Q X! H& N. I( ]# X2 `*********************/
8 ~" X2 t, L. g& ~( }" o7 t#include <stdio.h>
; ^3 j& I3 x5 P0 X7 l! p% H# `$ R#include <unistd.h> 9 c& v* h2 w, c4 K) h4 y- H
#include <string.h> 5 V! W& h5 {5 q
#include <errno.h>
( i8 m7 N( O: ^+ Q) {; z6 C$ C8 t#include <sys/types.h> 8 f+ O8 V M$ j
#include <sys/stat.h>
( M% o, [3 C# S#include <pwd.h> 2 v) M% ~9 ~- [% p1 ]+ r# q8 H7 w
+ V/ {% C# m7 U) O. o9 e
int main(int argc, char **argv) 4 g/ H& F! j* e' v3 f. Y( `
{ " t, R: Y2 u3 p4 u: [7 m: }: r0 U- p5 I
struct stat st;
: m7 \+ R+ f" FFILE *f;
, g5 c8 X: R7 R+ gchar *cfg;
+ N! X' `7 s- y. U; a* a6 ?% zstruct passwd *pw; 6 u: D9 O3 ^2 p2 B6 U0 s) C! O
uid_t uid;
9 I8 v3 c- P# {' X- t* @8 Ygid_t gid; " Y) F8 V/ }3 ?* F! d* J' K
char *dir, *shell;
! `0 ?7 @0 N" N5 N$ G! bchar *user=NULL;
5 D1 q! S/ ]" D+ j4 K9 b: R3 cchar *cmd=NULL; 0 @$ U1 c6 T- u1 r( M- p
9 Z0 s x( l8 Q# M) g$ Uuser="root";
# d; ~7 P) B1 T1 b; q8 C) a& g/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上,
! U: k1 e) d+ `- D6 \( P7 i5 i+ j登陆用户名应该从/etc/sysconfig/autologin中得到, 5 D4 ?. G; s1 I8 I
程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/
7 @! r" {; e6 o" Hcmd="/usr/X11R6/bin/startx"; $ Z& I( L& B8 r! Q3 q, u
/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ , Q; @0 p) p* i" s) T5 F/ M
- I7 K# y- Y4 b9 l
pw = getpwnam(user);
9 b' A/ k' U# p6 ?6 b9 o//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。
, S8 d% ~$ x8 ?* j2 \' w' cif(pw) { , Z' d7 h* {* n i5 J& z5 `: r- B
uid=pw->pw_uid; . Q# d b b# [6 j5 D; r1 i
gid=pw->pw_gid; dir=strdup(pw->pw_dir); ; o5 K3 a5 ]+ m
shell=strdup(pw->pw_shell);
' i$ A0 r/ q8 U( @# Q} 6 Z+ n9 k' h' [1 i/ b5 H
//获得用户相关信息 3 t/ W3 V8 r& b. A+ Z2 A3 [
else { 6 U; C* ~% X. P3 L+ U s% T" r9 s. @
printf("ERROR: No such user %s!\n", user); + F" _0 C0 M! g. o
return 1;
8 G! {0 d- Q( g( t}
5 G/ c7 E: R, S; J( D0 h
' b# z1 i' k0 B" }chown("/dev/console", uid, gid); * l6 L ^9 T8 G$ w
chown("/dev/tty", uid, gid); 5 H4 @+ C/ f8 U D! L! S( Y
//为控制台和终端设置用户ID及组ID
! H. R v8 r! H! E% i1 t
) V1 _) k0 [1 n, c//下面是设置用户相关ID 2 O3 T- n5 `" A: y* k& i3 S
setregid(gid, gid); 3 y- S" R/ |2 ]9 L
setegid(gid);
n# N! Q1 L# F! y' f& V# _1 `setgid(gid);
7 N+ k8 B9 r) n+ c% k9 Rsetreuid(uid, uid); ' o! d0 E& W+ e C2 Z
seteuid(uid);
, Q a, G" f' n3 isetuid(uid);
* R" V5 `( ]8 ]$ p# H( B
' F8 v. Y) P9 A+ [7 z) E' q( e8 Y; ~setenv("HOME", dir, 1); ; e8 ]4 o/ f0 W: H. w' U) g; C
setenv("SHELL", shell, 1);
$ \9 H' N- L5 X5 M* U, l# Osetenv("USER", user, 1);
, S! C: v# i" b( {( h9 a' A. e/ @setenv("LOGNAME", user, 1);
8 k. K1 j: ]- x7 K5 T9 @//设置用户相关环境变量 ; m% b. W8 Z4 y# [. [/ T
- [* Z C8 e6 Q6 D( }, _6 J! i
chdir(dir); 4 [2 d) ~- Y- l
//切换到用户根目录 ) I' d; Z. k+ S6 `" i' b
user=NULL; ) ], Q4 B2 u5 s
: L$ ?6 C" h/ z" O1 s) j4 vexecvp(cmd, argv);
1 f: f, b/ T$ I* ?/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */
0 I5 R) y+ L' E* Y' @$ b1 V3 Lprintf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno)); : `5 V; Y3 _0 v/ m
return 2; 4 ?7 t! a1 \ H5 G& f
}
7 T& f* e. t$ O" e( R0 o# `
! m) J' D ]0 w: ~ e& r
: y2 |8 l' W( K& J/ Z5 _- A+ o! R, t# K3 r' H7 \
! B& {) @# m6 M9 n运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
& k" j7 `4 N# p( T: r
+ K0 }6 Z# L) v3 b, o* |如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下:
9 l6 N& U. G% B+ n3 o) i6 m2 s
; o# S+ w" q0 C: \) O( w' b8 _
" ]8 F2 Q$ `" I+ x3 r9 B...... ' q- {8 v* j" H* L3 e) ]
# 第一步:查看是否为自动登录 * ?, y' [0 T/ T6 V! f$ Z
if /usr/sbin/autologin; then
9 C, p( s/ l( t/ y% P- `exit 0
. s6 n2 g' @+ }3 n' Gfi
. m6 X2 n8 A3 W( v* R$ \% R9 F//第二步 ...... 3 M5 W* \9 K# w2 X, {
......
, ~* I8 |+ }( C @' L& P: x
& l7 s! l, r$ d2 {2 q' P2 |4 p Z , M( N g0 T: a6 X" M$ [
' r+ x# N! U7 s8 V; ^
7 h3 {* g# [* h( n9 T, H
即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
$ Q D6 P1 x [* p: N( l! P$ c) o( I4 u4 U! y6 u
四、选择进入kde或者gnome,并自动启动X window应用程序 1 w: ?4 B3 l. y ^ ^
6 y, r6 A" Q* S2 [' `如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 , |& y$ P/ L# i% `0 J/ {
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。 0 f3 }' o8 [# h9 h
/ B1 D: E9 z* i& h0 j! ?
# } _8 W" U7 N0 E/ hhttp://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|