- 在线时间
- 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) ) P4 D I O8 j$ B* K
, q+ p) D% |6 k2 l4 y+ M
机自动登录linux,并自动运行X window应用程序,有其特殊的应用背景,如基于linux平台的监控系统,linux启动后不需要身份验证,而直接运行监控程序等等。本文以Redhat7.2为平台,结合linux启动过程,介绍了如何避免身份验证自动登录,并直接进入X window自动运行应用程序。
# i C# |# K) r. j4 M( k ]( G1 y一、linux启动的最后阶段的工作 / k* k& h( k* V f7 L) Z; x
: y' b" P" Q5 }5 A- Slinux 在启动过程的最后阶段(具体启动步骤略),init 会根据 /etc/inittab文件的最后一行x:5:respawn:/etc/X11/prefdm -nodaemon运行/etc/X11/prefdm脚本,(Red hat 7.2缺省时是这样的)。prefdm脚本的主要任务是完成X window的启动,可以有几种启动X window的方法,都包含在prefdm脚本中,几种主要方法有:
+ b O/ n6 L4 a- v$ M4 Q/ ]$ w, [4 F; {
运行xdm启动X window; 5 M1 ~8 h8 F' |$ x# C/ ~' y
运行gdm,进入gnome桌面环境;
; B/ J3 h# n+ G4 o6 s; G- f) L3 {% h运行kdm进入kde桌面环境; % R! q8 t. J0 o2 j) h2 p5 u7 D
自动登录进入linux; ' \8 H+ x- l( r( d: q$ k6 x; z' p
prefdm脚本框架大致如下: 9 X) ^* L8 T2 ]9 M1 {2 f
1 }% ?" N' c9 h) U( G#!/bin/sh # I6 X' S, e9 U7 }# U7 n% M% A3 ^# o
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin
* G! d) H: A" |( k: F. ~. /etc/profile.d/lang.sh ! l, ^; i' y9 W: f
# 第一步:查看是否为自动登录 # w+ L/ `4 C5 e
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then 7 O& a Q* c6 M3 S) q$ n
if /usr/sbin/autologin; then & {! c# \. Y$ M
exit 0 4 o1 F4 M" w7 O9 Q
fi
2 o; m( t( } P9 v1 hfi ; A; q% E' N! _6 H
# B* q& z* ] {% v( X
# 第二步:如果不是自动登录方式,就会在/etc/sysconfig/desktop中搜寻用户偏爱的登录方式
* q* l% U2 `* L......
3 _& C8 t2 C X3 P# 可以是kdm、gdm以及xdm,并运行相应的kdm、gdm以及xdm。 5 A4 q0 r! \# K: ]8 D
......
* Y s @3 }7 P2 v( N+ A' P! N
; M) s* _" u! a1 \% a5 s; T8 B
5 e- v0 _8 q O0 A) T
3 g! R8 w$ c( i
, q4 y, u$ w7 r7 ~) d" D, l二、自动登录的实现(autologin的实现)
. O# |4 m" G$ w, Z) a+ K) D; C) I/ k" U
在/etc/X11/prefdm脚本中,是否实现自动登录有一个条件测试开关,事实上,可以在这里注释掉测试开关,直接执行启动X window的操作。
0 j, l6 o$ }: K/ W& C* s% }$ p9 B# D7 D8 {* T7 H
自动登录实质上就是绕过身份验证,直接启动X window。X window的启动可以由xinit来完成。 $ m/ M0 Z/ ?0 z& Q
9 \2 `! t$ o+ g9 B/ q8 y, `
Xinit用来启动X window系统服务器以及系统上的第一个客户程序,可以通过为xinit传递命令行参数的形式指定要启动的服务器及客户程序。如果不传递参数给xinit,它将在用户的根目录下寻找并运行 .xinitrc脚本来启动客户程序;在用户的根目录下寻找并运行 .xserverrc脚本来启动服务器。如果xinit在用户的根目录下找不到.xinitrc、.xserverrc,xinit将使用缺省的X :0。
/ b- b1 {7 Y0 ?) e/ T. k1 B7 X实际上,用startx来启动X更为方便。对于运行单一会话的X window 系统,startx提供了更为良好的用户接口。同样,startx首先在用户的根目录下寻找 .xinitrc及.xserverrc脚本,如果找不到这两个脚本,startx将使用/etc/X11/xinit/xinitrc以及/etc/X11/xinit/xserverrc脚本。
8 @+ {$ {; N: m# gstartx脚本的最基本框架是: & a9 I5 I, Q) S0 h6 L! V7 p9 h7 t& A
/ {- ?7 h# g1 a% H
a、 寻找.xinitrc,如果没有则使用xinitrc; # I1 ?/ E+ m2 Y* `4 p2 ^9 D
b、 寻找.xserverrc,如果没有则使用xserverrc; 2 Z( i! g! D5 p% E+ Z
c、 根据找到的脚本确定xinit的参数;
" N. x! p9 N/ |* M( |0 g9 _: \+ @9 [6 m! f
由此可看出,startx在不需要传递任何参数的情况下,可以完成启动X的任务,因此,可以如下修改/etc/X11/prefdm脚本来实现自动登录: - U9 ?# q, P' Y. M9 k$ ?
7 S$ q! x& T$ P3 ?; x& U! z, K
, D, t. A! C7 { E! X4 @# K
#!/bin/sh ! `7 {7 [/ k; W4 y1 j9 b5 W
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin 1 o" e2 {5 O; j8 h) J3 `, |- b
. /etc/profile.d/lang.sh
5 a( M' ^6 A& Q. ?1 r# 第一步:查看是否为自动登录 2 E* Q" G8 r" q9 Z5 H
#if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then
) I+ I# h+ E+ v#注释掉上边的条件测试,直接运行startx . p; |) ]# X& z& c- F( ? ^2 e& v0 a
if /usr/X11R6/bin/startx; then
$ f' b. v! D: ~ ]$ y- Z6 bexit 0 2 V% A9 |! L5 W) R
fi , n4 J% A8 @+ |9 c9 L$ T
#fi
' H) c, f$ W- K1 F- d1 K* U; ? r# k/ \: W5 z
8 j: `7 S5 ^3 G" u
& x- D3 C( y: X2 e2 \8 r) b" Y
: _3 p; `7 T) W/ m8 J1 [
当然,应确保/etc/inittab中的启动级别为5。 4 E4 Q2 ^) g% S9 @3 z4 s7 g7 d4 ?
@ o2 i' n# I8 N! C. U6 H重新启动系统,会发现系统不验证用户身份,直接进入X window,此时的用户身份为root。但是,如果原来root有自己的桌面、默认shell时,上述方法启动X不一定保证还能拥有原来的设置。为了在启动X后,在避免验证身份的同时,又不改变用户原来的设置,那么在运行startx之前,还有工作要做。
& H4 H4 e. U6 u" s# o9 X
/ T: R5 S5 F6 O' k三、自动登录后,保持用户原来的配置(桌面、shell以及其它的一些环境变量)。 3 g6 g# c9 Q, y* k: l
" C" ]3 g2 N. _0 f. }$ s( n观察原来/etc/X11/prefdm脚本的自动登录部分: 6 V: l; M- M! I$ ]
+ t+ H% ?8 H Z: Y% t( f
1 n$ ^# h$ e3 ]7 b) U) I: {1 d: R3 b......
3 ^3 k5 |; f9 ~1 o# 第一步:查看是否为自动登录 & ^0 w9 @7 g" Y
if [ -f /etc/sysconfig/autologin -a -x /usr/sbin/autologin ]; then % X: H" j$ j; K3 n# t
if /usr/sbin/autologin; then
# @& H- U7 W# _/ [1 B0 `) Aexit 0
) U9 n5 s1 ^1 Q- X: s( nfi
/ ? f) c6 i' Z9 _8 Lfi
& z0 o) q& A8 x# }0 G- {...... + Y" o" [5 B6 p4 q; g$ _
$ G/ V& }) \8 V7 ^4 T/ Y
. x3 B& z) E9 Q b
$ Y$ U! Z* @3 f: f
# q" ~' a0 z* ]! q; h$ d不难看出,脚本中保留了自动登录的接口:一个可执行文件/usr/sbin/autologin以及一个配置文件/etc/sysconfig/autologin。
. R4 M2 ^: H9 B
2 R( G6 F; i, K* ^1、/etc/sysconfig/autologin配置文件的实现: , h" {6 ~! G1 d% G+ o4 A$ R) S
) y& W/ c8 e3 M" l
( [. Q/ F2 h5 @( L/ U
#config for autologin
$ j# `; ]% n3 j/ x$ y% WUSER=root 2 Z W( O. s# K4 I6 w
EXEC=/usr/X11R6/bin/startx 3 |* Z) O7 m* C8 p
说明,USER指定自动登录时的用户名;EXEC指定启动X要运行的程序。
O6 F2 f% _+ t0 v9 g6 v- i, A
^' f2 D4 z1 p% z* D# ` : l% U+ H; m: t- |0 h/ W r
! e* `8 ^5 z4 T" u. t& O7 v$ t+ x8 J* T
2、/usr/sbin/autologin可执行文件的实现:
+ F: p* a" f' j9 G# Y0 V
3 K; ] f7 x6 S8 T- f, K& }& t% u8 b2 x* h& b& e2 g
/*********************
, |( I7 v6 d7 R1 [ o$ r% s**** autologin.c **** % C' L; g2 D( b: f
*********************/ # {% w# `/ m4 p3 V0 P% O$ p
#include <stdio.h>
$ u: b7 t5 U) h7 ]! _; C#include <unistd.h> 7 r+ E) e& G' t' S) `( P9 {
#include <string.h>
+ k0 F( w# [5 a& z#include <errno.h>
6 Z4 w9 v3 E5 \/ p: v$ I0 z#include <sys/types.h>
$ A* f: J& [6 X#include <sys/stat.h> % d# z9 }/ W2 z3 E
#include <pwd.h> ) J! i$ @$ J! l$ R1 T k3 Q
6 N$ N% Z2 [* dint main(int argc, char **argv)
0 i0 Q; K2 P" g; N{ 9 ~% l' }2 a' {8 X3 @
struct stat st;
s ]( q# m# W7 h$ wFILE *f; * y: B' L6 K' Y5 r$ R$ I
char *cfg; 5 l& d( l! |* H- R& ~2 u
struct passwd *pw; " A5 H% c q" L5 o4 U& c2 {4 Y
uid_t uid;
( \6 B+ F/ }2 U. b4 _1 }gid_t gid; : }8 X: n1 B+ o" T" n
char *dir, *shell; 5 Z; p9 i, n6 ]9 A: _& [
char *user=NULL; & f& C* \2 I7 s5 F& E
char *cmd=NULL; ; Z: F% T5 x$ c
! Z6 f- K! ^. k7 `6 p: N. w: l
user="root"; ( j6 a0 e0 B7 ^3 }- N8 j* U; _, p0 G
/*为了能说明问题又保持程序简洁,这里默认登录用户为root,实际上, 9 y* z7 a2 P5 L9 Q* ]) b! \7 N
登陆用户名应该从/etc/sysconfig/autologin中得到, ! y* z! Z, v+ S. e8 _
程序实现时要注意过滤掉/etc/sysconfig/autologin中的无效用户名*/ * Z9 l& W8 {) n5 i# h" @' _3 K% P
cmd="/usr/X11R6/bin/startx";
9 s/ F. ~' C. B( a0 Z- p/*同样,这里直接指定启动X window的程序,实际上,该程序应该从/etc/sysconfig/autologin中得到*/ 5 g) J9 C: T3 g- u% n; g8 j; Q
: ?6 |" Z* F0 }2 vpw = getpwnam(user);
R% s$ Y" Q; Z8 ^+ S: X//getpwnam返回包含用户信息的passwd结构(该结构在pwd.h中定义)。 % S7 ?9 P; z; t$ `. b
if(pw) {
/ G9 L3 Q% z- Z1 Cuid=pw->pw_uid;
7 M$ f+ h- e& L* J& _gid=pw->pw_gid; dir=strdup(pw->pw_dir); # w; z: V0 o+ r; [$ E. |& j/ c
shell=strdup(pw->pw_shell); + L2 ~1 h6 i( I- p) G' u
}
! N& E: q8 F& r) w//获得用户相关信息 % s0 @5 {; j0 [ L7 m7 t7 A9 j4 D6 e7 G
else { ( P+ h' h* Q1 z3 M
printf("ERROR: No such user %s!\n", user); 4 ?' N) O# m/ C- U% O( g# Z
return 1;
3 C) \1 r- j" m, w* g}
! H* O+ `! u* {& I* w, ^' f O5 b, q( D: s
chown("/dev/console", uid, gid);
$ v3 n2 R9 M* U& s* T# X/ ?chown("/dev/tty", uid, gid); 3 b8 u6 B5 J. v( E* q7 l) F) w
//为控制台和终端设置用户ID及组ID
; w; E/ d% T. Z! S* P0 T- @6 R& G) L; G. u. s+ j
//下面是设置用户相关ID ' L2 {/ a- ]+ F. w: @ w; q& Q5 a
setregid(gid, gid);
$ E- U1 X: S0 c+ E2 @setegid(gid); - a& L }5 @* L' |) S
setgid(gid);
# L. S' x' H3 g$ }6 k6 Ksetreuid(uid, uid); & |1 d) ~5 v( r8 G/ T9 l3 Y0 K
seteuid(uid); % p0 k: ~" H7 o' R7 ?; Y' D
setuid(uid); - D' ~. r$ R6 u
8 |9 H7 H! H$ T. j6 ssetenv("HOME", dir, 1); - P; X! X$ }$ F( |
setenv("SHELL", shell, 1);
; P% f4 D' V" w% Jsetenv("USER", user, 1); - {) g0 |+ M; u! \9 I
setenv("LOGNAME", user, 1); % t2 t8 \ d+ u+ L% G0 V S5 g6 m
//设置用户相关环境变量 8 h& c4 @# V+ s7 b
+ w6 s% b: } @( Y) \" ?# Pchdir(dir);
& V; R- c4 p( q1 a8 [//切换到用户根目录
# U# ~6 h$ K" W7 ]user=NULL;
6 |# I" A. q* ~& A, s( X) v7 Q% A2 A1 A. e: k! A% z M
execvp(cmd, argv); " Z) j! h9 X2 R4 ~# L9 B
/*在配置完用户的相关信息后,执行启动X window操作。注意这里默认执行/usr/X11R6/bin/startx */ ) t$ [1 F* h- v8 F
printf("ERROR: Couldn't exec %s: %s\n", cmd, strerror(errno));
8 |! b: l. q: Breturn 2; 8 V; h* ^" O& \' X
} / O. D/ l; k& Z, K z* Z1 z
; K; K" Q* u+ X, A" G
( B" V- z1 t7 f2 S6 K- x' W3 w
D$ s Z3 ]3 U6 E1 O+ t/ u
9 X% C/ _' x. o; s" t6 }
运行gcc -o autologin autologin.c,拷贝autologin可执行文件到/usr/sbin/autologin,拷贝autologin配置文件到/etc/sysconfig/autologin。 重新启动系统,会直接进入X window并保留用户原来所有的风格。
$ Q% ?: z, X) C* u, \1 f
6 C$ r% X' |" b7 b1 g如果不需要自动登录的配置文件/etc/sysconfig/autologin,所有的操作都在/usr/sbin/autologin以默认的方式实现(比如,默认登录身份为root,默认执行操作为/usr/X11R6/bin/startx等),那么,/etc/X11/prefdm脚本的自动登录部分可简化如下: ) k: b/ x3 L4 e/ ^: v
7 i4 e' \% J# V3 M: O) l7 \. w) f) s8 n. G {
......
" M& F+ Q: b1 R4 r H6 Y9 u0 |# 第一步:查看是否为自动登录 ' q" w) t( I1 J9 Y% g9 [' R' L; C
if /usr/sbin/autologin; then
' h/ P- ^0 T) d2 |& ~exit 0
& Y1 l* h3 l' P5 R% c pfi - D: a/ n0 M# m: d7 ?) B
//第二步 ......
! ^/ F2 f% U% J* k......
. u; a6 U; O" Z. P5 b) w! i) m( y
1 L; w5 \; [3 j$ q4 x7 s8 Z
* f$ a, r& ]% j) t) Q' `
$ j- v9 c* ?& H' h+ p& s% _即在脚本中去掉条件测试开关,直接执行/usr/sbin/autologin,这时,只需要拷贝autologin可执行文件到/usr/sbin/autologin,不再需要拷贝autologin配置文件到/etc/sysconfig/autologin。
( ~4 V8 b$ v/ P, U: g8 c6 n( f
) v I5 h0 t6 ^2 `' b四、选择进入kde或者gnome,并自动启动X window应用程序
) T. \* o T. m9 `2 J9 |* h' q/ n8 b p+ K2 P8 A9 D5 K* A
如果重新启动后系统进入了kde,而用户需要进入gnome,只需运行switchdesk gnome在重新启动系统即可,以后每次启动时会自动进入gnome;反之亦然。 + c& }. F; w) g3 h Y: K l
一般系统自动登录的目的是启动X window 后自动运行某个X window程序。如果系统默认的启动级别为3,那么如果要在系统启动后自动运行某些应用程序,只需要在某些脚本中加入相应命令即可,不再详述。在X window启动后自动运行应用程序要复杂一些,幸好,kde和gnome都为此留下了自动启动接口。如果在kde桌面环境下自动启动应用程序,只需要把应用程序名字加入/root/.kde/Autostart/目录下即可(这里注意不同用户的根目录可能不同,如用户zyx的根目录可能为/home/zyx)。如果在gnome桌面环境下自动启动应用程序,只需把应用程序的名字加入/主菜单/程序/设置/会话/会话特性及启动程序的startup programs属性页中即可。 : }7 Y8 \7 a$ f2 L) n% \8 M+ D) v0 V
; n/ M: Q1 R ]' X& _5 ?
Q8 E8 Z* u! j( p/ w# B. [/ Yhttp://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip20/index.shtml |
|