2. 시스템 관리에 관한 질문들
2.1 루트파티션의 용량을 작게 잡아서 가득찼습니다.
여러가지 방법이 있습니다. 가장 확실한 방법은 충분한 여유가 있는 하드디스크를 붙여서 부트디스크를 복사하는 방법입니다. 하지만 이 방법은 성공하기가 힘든(?) 단점이 있습니다. 임시방편으로는 몇개의 디렉토리를 다른 파티션으로 옮기고 링크를 만드는 방법이 있습니다. 이때 많이 애용(?)되는 파티션으로 /var가 있습니다. /var전체나 /var안에서 디스크를 많이 차지하는 파티션을 다른곳으로 옮기고 링크를 만들어 주면 됩니다. (절대 /sbin이나 /etc같은 디렉토리를 옮기지 마세요. ^_^)
2.2 하드디스크 파티션은 어떻게 잡는게 좋나요?
개인적 취향(?), 사용하는 응용프로그램에 따라 다릅니다. 아래는 안진수님이 뉴스그룹에 올려주신 내용입니다.(참고하세요.)
/ 64MB
/usr 400MB 이상 (최경렬님은 최소 600MB이고, 보통 1GB이상을 잡는게 좋다고
메일을 보내주셨습니다.)
/var 128MB 이상 (Recommended Patches를 설치하려면 적어도 100MB가
필요합니다.)
swap 물리적 메모리의 2배에서 4배
/opt 400MB 이상
/usr/local 분리권장
저도 위와 비슷하게 파티션을 나누고 대부분의 프로그램은 /usr/local이나 /opt에 설치합니다.
2.3 swap영역이 모자라는데 어떻게 추가할 수 있나요?
Solaris 2.x에서는 초기에는 따로 파티션을 잡아서 swap영역을 사용하지만 나중에 추가할 경우 swap파일을 만들어서 추가합니다. 이때 사용하는 명령어가 mkfile 입니다. 만일 /opt/swap이라는 200MB짜리의 파일을 만들어서 swap영역으로 쓰고 싶다면 아래와 같이 파일을 만들고 swap명령어로 추가할 수 있습니다.
% mkfile 200m /opt/swap
% swap -a /opt/swap
만일 항상 사용할 swap영역이라면 /etc/vfstab에 추가하면 됩니다. 다음은 /opt/swap을 추가한 /etc/vfstab의 예제입니다.
% cat /etc/vfstab
.
.
swap - /tmp tmpfs - yes -
/opt/swap - - swap - no -
%
2.4 inode full이 나옵니다.
파일시스템에서 사용하고 있는 inode를 모두 사용했기 때문입니다. 이렇게 되면 더 이상의 파일을 생성할 수 없습니다. 파일들을 백업한 후(문제가 되는 파일 시스템만 백업하면 됩니다.) newfs의 -i옵션을 사용하여 inode의 갯수를 늘이고 백업한 파일들을 복구해야 합니다.
2.5 사용자마다 특정크기만큼만 하드디스크를 할당하는 방법이 있을까요?
Solaris 2.x라면 quota를 설정하시면 됩니다. quota를 설정하는 방법은 Solaris메뉴얼중 System Admin Guide Vol2에 보시면 잘 나와있습니다. How to enable user storage space quotas for Solaris in a mounted file system 간략하게 설명드리면 아래와 같습니다.
/etc/vfstab에서 quota를 설정하고자 하는 파일시스템의 마운팅 옵션에 rq를 지정한다.
$ cat /etc/vfstab
..
/dev/dsk/c0t2d0s6 /dev/rdsk/c0t2d0s6 /home ufs 1 yes rq
..
quota를 설정할 파일시스템에 quotas라는 파일을 만든다.
$ touch quotas
$ chmod 600 quotas
각 사용자에게 quota를 할당하기 위하여 edquota라는 명령을 사용한다.
$ edquota louis
fs /home blocks (soft = 0, hard = 0) inodes (soft = 0, hard = 0)
여기에서 할당하고자 하는 양만큼 soft와 hard부분에 적어준다. 만일 20MB를 할당하려면 아래와 같이 해준다. (만일 quota를 제거하고자 한다면 0을 적어주면 된다.)
fs /home blocks (soft = 20000, hard = 20000) inodes (soft = 0, hard = 0)
만일 다수의 사용자에게 같은 양의 quota를 할당하려면 하나의 사용자만 할당하고 복사할 수 있는데 아래는 louis 사용자의 quota설정을 aaa, bbb, ccc 사용자에게도 똑같이 할당하는 예제이다.
$ edquota -p louis aaa bbb ccc
2.6 cachefs가 뭔가요?
http://white.ce.kyungpook.ac.kr/~louis/papers/cachefs/를 읽어보세요. 설명과 기본적인 설치법이 적혀 있습니다.
2.7 네트웍으로 root접속이 가능하게 하려면?
기본적으로 Solaris 2.x에서는 네트웍으로 접속하고 root로 로긴하면 아래와 같은 메세지를 출력하고 접속이 안됩니다.
login: root
Password:
Not on system console
Connection closed by foreign host.
Solaris 2.x는 기본적으로 root사용자는 console에서만 로긴이 가능합니다. (su는 제외) 이것을 console이외에서도 가능하게 하려면 /etc/default/login에서 CONSOLE=/dev/console에 주석을 달면 됩니다.
참고로 CONSOLE=/dev/console의 의미는 root는 /dev/console에서만 login이 가능하다는 의미입니다. 만일 root사용자로 로긴이 불가능하게 하려면 CONSOLE= 와 같이 해 두면 됩니다. (하지만 이 설정은 기본적으로 설치된 in.telnetd등에만 해당됩니다. 만일 ssh등을 사용한다면 이 파일과 상관없이 root계정으로 로긴이 가능합니다.)
2.8 로긴화면에서 나오는 메시지를 바꾸려면?
telnet으로 접속시 UNIX(r) System V Release 4.0 (white) 같은 메세지를 바꾸고 싶다면 Solaris 2.6의 경우 /etc/default/telnetd에서 BANNER 항목을 수정하면 되지만, 그 이외의 시스템에서는 특별한 방법이 없습니다. 몇분들의 말을 따르자면 binary파일(in.telnetd)을 수정하면 가능하다고 하더군요 :)
콘솔에서의 white console login: 메시지는 /etc/inittab에서 수정할 수 있습니다. 기본적으로 "`uname -n` console login: "으로 되어있습니다.
로긴화면에 여러줄의 내용을 출력하려면 /etc/issue에 적어주면 됩니다. 그리고 로긴후 여러줄의 내용을 출력하려면 /etc/motd에 적어주면 됩니다.
로긴후 나오는 메시지들(motd내용, 최근접속일등)을 나오지 않게 하려면 $HOME/.hushlogin 을 만들면 나오지 않습니다. (touch $HOME/.hushlogin)
2.9 한번만 접속을 하면 같은 이름으로 로긴을 막고싶습니다.
기본적으로 지원해 주는건 아니지만 /etc/profile이나 /etc/.login에서 간단한 script를 써서 구현할 수는 있습니다. 또한 Michael P. Crider가 만든 idled를 사용하셔도 됩니다. idled는 http://www.darkwing.com/idled/README.html에서 구할 수 있습니다.
2.10 floppy드라이버를 사용하려면 어떻게 해야 하나요?
Solaris 2.x에서는 vold(Volume Management Daemon)을 이용해서 floppy나 CD-ROM을 마운트합니다. 따라서 floppy를 사용할때는 드라이버에 디스켓을 넣고, volcheck명령어를 실행하면 마운트가 됩니다. 보통 /floppy/floppy0에 마운트가 됩니다. 그리고 디스켓은 MS-DOS 포맷으로 되어있어도 문제가 없이 마운트됩니다. 그리고 다 쓰고 났을때는 eject floppy를 입력하면 floppy가 빠져나오며 자동으로 마운트가 풀립니다.
2.11 CD-ROM드라이버를 이용하려면 어떻게 하나요?
Solaris 2.x에서는 floppy와 마찬가지로 vold를 이용해서 마운트합니다. 현재 vold가 수행중일때는 CD-ROM의 경우에는 CD를 삽입하기만 하면 자동으로 /cdrom에 마운트가 되고, CD를 빼고 싶을때는 CD-ROM드라이버에 있는 버튼을 누르거나, eject cdrom이라는 명령어를 입력하면 됩니다. (가끔 CD-ROM 드라이버의 버튼을 눌렀을 때 CD가 빠져나오지 않는경우가 있습니다. 이때는 eject cdrom 이라고 입력하면 잘 빠져나옵니다.) 참고로 vold의 설정파일 은 /etc/vold.conf이며, 자세한 사항은 vold(1M)의 메뉴얼을 참조하시기 바랍니다.
2.12 다른 시스템의 CD-ROM드라이버를 이용하려면?
만일 두대의 컴퓨터 A, B가 있는데, A에는 CD-ROM 드라이버가 있고, B에는 없어서 B에서 A의 CD-ROM 드라이버를 이용하고 싶다면, A에서는 /etc/rmmount.conf 의 마지막에 아래와 같이 추가하고 vold 데몬을 다시 실행한 후
share cdrom* -o ro=B
B에서는 /cdrom에 사용하고 싶다면
% ln -s /net/A/cdrom /cdrom
와 같이 연결해 두시면 됩니다.
참고로 Solaris에서는 CD-ROM이나 floppy등은 vold(1M)가 관리합니다. 만일 어떤 사용자가 CD를 넣으면 vold는 그 일을 감지하고 rmmount(1M)를 호출해서 다시 마운트해줍니다. rmmount(1M)는 CD나, floppy와 같은 장치들을 마운트할 때 사용하는데, 그 설정파일은 /etc/rmmount.conf입니다. 자세한 내용은 rmmount.conf와 rmmount의 메뉴얼을 참조하세요.
2.13 Sun용 CD-ROM드라이버가 따로 있나요?
따로 있지는 않습니다. Sun에서는 SCSI CD-ROM드라이버중 버퍼가 512K바이트인 것만 지원합니다. 잘 돌아가는 모델에는 소니의 경우 CDU-8012모델(Sun 1배속 CD-ROM드라이버), 도시바의 4101TA모델(Sun 2배속 CD-ROM드라이버), 3301B모델, 3401B모델, 애플의 CD 300i가 있으며, 플랙스터의 CD-ROM드라이버의 경우 대부분 잘 돌아갑니다. 만일 구입을 하신다면 플랙스터의 모델을 구입하시는것이 좋습니다.(최경렬님, 이석찬님)
2.14 새로운 장치를 달고 device file을 만들려면?
일단 다른 주변장치와 충돌하지 않는 SCSI번호(CD-ROM드라이버는 일반적으로 6번을 사용하고, Tape드라이버는 일반적으로 4번을 사용합니다.)를 할당하고, PROM prompt에서 probe-scsi명령으로 정상적으로 인식이 되는지 확인합니다. 여기에서 잘 나오면 boot -r명령으로 /dev와 /devices의 파일들을 갱신하면 됩니다.
ok probe-scsi
ok boot -r
보통 외장형 Tape드라이버를 달고 이 작업을 수행하는데 이때 생기는 장치파일은 Solaris 2.x의 경우 /dev/rmt/0 (SCSI 4번을 쓴경우), /dev/rmt/1 (SCSI 5번을 쓴 경우)이며, SunOS 4.x의 경우에는 /dev/rst0, /dev/rst1이 생깁니다.
2.15 Tape의 내용을 삭제하려면?
Tape의 내용을 삭제하려면 mt명령을 사용하시면 됩니다. 만일 Tape드라이버의 장치파일이름이 /dev/rmt/0 라면 아래와 같이 입력하시면 됩니다.
$ mt -t /dev/rmt/0 erase
2.16 Workstation의 화면 해상도와 색상수를 바꾸려면?
Sun Workstations의 경우 화면해상도와 색상수등을 변형하려면 사용하는 Video Card가 framebuffer를 지원해야 합니다. 보통 Creator 3D에서는 사용가능합니다. 만일 콘솔의 해상도를 1280x1024로 변경하려면 PROM prompt에서 다음과 같이 입력하면 됩니다.
ok setenv output-device screen:r1280x1024x64
ok reset
이렇게 PROM prompt뿐만 아니라 ffbconfig 프로그램을 이용할 수 있습니다.
만일 Solaris x86에서 화면 해상도를 바꾸려면, kdmconfig 명령을 이용해서 화면해상도를 변경할 수 있습니다. Solaris x86에서 화면해상도를 변경하기 전에 현재 사용하고 있는 Graphic Adapter가 Solaris x86에서 지원하는지를 확인한 후 실행하시기 바랍니다. (신제철님)
색상수를 16bit색상으로 바꾸려 할때, openwin을 사용하신다면, openwin -dev framebuffer 장치파일명 defdepth 16 과 같이 하시고, CDE를 사용하시면 /usr/dt/config/Xconfig 파일에 Xsun -dev framebuffer 장치파일명 defdepth 16 과 같이 설정하시면 됩니다. 제가 사용하는 Creator 3D의 경우엔 framebuffer 장치파일명이 /dev/ffb0 입니다. (당연히 framebuffer가 원하는 색상수를 지원해야 합니다.)
2.17 Solaris 2.x에서 두 개이상의 Network Adapter를 설치하려면?
Network Adapter를 달고, /etc/hostname.hme?,/etc/hostname.le? (100M Network Adapter이면 hme0, hme1, .. 10M Network Adapter이면 le0, le1, ..)에 각 Adapter의 호스트이름을 작성하고, /etc/hosts에 IP Address를 설정하면 사용할 수 있습니다.
2.18 프린터를 병렬포트에 연결하려면?
Sun Workstation의 병렬포트는 시스템의 종류에 따라 다릅니다. 일단 병렬포트가 있는지 확인하시고 (그림에 // 와 같이 그려진 부분이 병렬포트입니다.) 형태에 맞는 병렬케이블을 구입해서 사용하시면 됩니다.
2.19 모뎀을 달려면?
ftp://sunsite.snu.ac.kr/pub/sun-info/sun-faq/FAQs/Solaris2.x-Modem-and-Terminal-Setup을 참고하세요.
2.20 Postscript파일을 출력하려면?
postscript을 지원하지 않는 대부분의 프린터에서 postscript파일을 출력하려면 gs(ghost script)를 사용하면 됩니다. 그리고 postscript를 지원하는 프린터일 경우에도 한글파일들을 출력하려면 gs를 사용하시는게 좋습니다.
gs를 필터로 사용하는 방법은 http://cfauvcs5.harvard.edu/SetGSprinter4Solaris.html를 참고하시기 바랍니다.
그리고 잉크젯 프린터를 이용하여 Color로 출력하려면 해당 프린터의 gs dev파일을 구하셔서 gs를 재 컴파일 하면 됩니다. stylus color프린터는 dev파일이 기본적으로 들어있으므로 컴파일이 Makefile의 DEVICE_DEVS에 stcolor.dev를 추가하면 됩니다. HP의 잉크젯은 http://www.erdw.ethz.ch/~bonk/hp850/hp850.html에서 dev파일을 구할 수 있습니다.
2.21 네트웍을 지원하는 프린터를 설치하려면?
HP의 제품인 경우 HP의 홈페이지에서 JetAdmin을 받아 패키지를 설치한 후 (/usr/hpnp에 설치한 경우) /usr/hpnp/jetadmin으로 프린터를 추가하면 됩니다. 물론 IP와 Netmask등은 설정해 두셔야 합니다. (서진수님)
2.22 JAZZ드라이버나 ZIP드라이버를 달려면?
JAZZ드라이버나 Zip드라이버는 SCSI를 사용하는경우 일반 디스크처럼 사용하실 수 있습니다. 단지 주의하셔야 할 내용은 미디어를 뽑기전에 umount를 하셔야 합니다.
2.23 백업 하려면?
여러 가지 명령어가 있지만, 가장 기본적인 tar에 대해 말씀드리겠습니다. 만일 /home 디렉토리 이하의 파일들을 /dev/rmt/0에 백업받으려 한다면 다음과 같이 입력하시면 됩니다.
% tar cvf /dev/rmt/0 /home
나중에 백업한 내용을 restore하시려면 /에서 다음과 같이 입력하면 됩니다.
% tar xvf /dev/rmt/0
tar를 사용하는경우 원하는 파일만을 restore하려면 아래와 같이 사용하시면 됩니다. (man tar에서 가져옴)
% tar xvf /dev/rmt/0 `tar tf /dev/rmt/0 | grep 'pattern'`
이 외에도 restore하고자 하는 파일의 리스트를 파일로 만들고(e.g list), 다음과 같이 사용하셔도 됩니다.
% tar xvf /dev/rmt/0 -I list
2.24 Solaris 2.x에서 /dev/rmt/에 있는 장치파일들의 의미
Solaris 2.x에서 Tape드라이버를 달고 device파일들을 만들고 나면 /dev/rmt/디렉토리에 많은 파일들이 생깁니다. 이 파일들은 그 이름에 따라 Tape을 사용하는 방법이 다른데 간단하게 알아보면 일반적으로 파일명은 아래와 같이 생겼습니다.
#[lmhc][b][n] (#는 숫자)
l,m,h,c는 기록밀도입니다. 각각 low, medium, high, compress를 의미합니다. 단순히 장치파일만 생겼다고 모두 지원하는건 아닙니다. compress를 지원하는 드라이버가 있고, 아닌 드라이버가 있습니다. 그리고 b는 BSD호환의 의미이며, n은 no-rewind의 의미입니다. 따라서 n이 없는 장치파일을 이용해서 백업을 하면 백업이 끝난 후 rewind를 하지만, n이 붙은 장치파일을 이용하여 백업을 하면 rewind를 하지 않습니다. 따라서 하나의 장치에 여러개의 볼륨을 백업하려면 n이 붙은 장치명을 사용해야 합니다.
2.25 다른 시스템의 테잎 드라이버를 이용하려면?
여러가지 방법이 있겠지만, 가장 간단한 방법은 rsh를 이용하는 방법입니다. 먼저 테입드라이버가 있는 시스템에 .rhosts파일을 만들어서 다른 시스템에서 rsh로 접속할 수 있게 한후 테입드라이버가 없는 시스템에서 다음과 같이 입력하시면 백업할 수 있습니다.
% tar cvf - [파일들] | rsh [테입드라이버가 있는 시스템] dd of=/dev/rmt/0
만일 테입으로 부터 파일을 풀려고 하면 아래와 같이 입력하시면 됩니다.
% rsh [테입드라이버가 있는 시스템] dd if=/dev/rmt/0 | tar xvf -
2.26 patch가 뭔가요?
Sun Microsystems에서 처음 Solaris등의 프로그램을 배포한 후 그 이후에 발견되는 버그들에 대해 수정한 파일을 patch파일이라고 합니다. 만일 105393번을 patch하라고 한 경우 105393이 patch번호입니다. 위와 같은 경우 105393번 patch파일을 구해와서 patch해주면 됩니다.
patch중에는 일반 patch파일과 recommended patch가 있는데, recommended patch는 이름에서 알 수 있는 것 처럼 추천하는 patch입니다. 운영체제나 프로그램의 보안상의 버그등 중요한 내용이므로 반드시 patch해주는 것이 좋습니다.
Sun Microsystems에서 patch파일을 배포하는 장소는 ftp://sunsolve.sun.com/pub/patches이고, 국내에서도 여러곳에서 미러링을 하고 있습니다. 대표적인 곳으로 ftp://sunsite.snu.ac.kr/pub/sun-info/sun-patches와 ftp://ftp.kreonet.re.kr/pub/Sun/sun-info/sun-patches가 있습니다. 가까운 곳에서 patch파일을 가져오시면 됩니다.
patch파일을 설치하는 방법은 patch파일의 README에 잘 설명이 되어있습니다. 일반 patch파일의 경우 압축을 풀고 디렉토리에 있는 installpatch를 root권한으로 실행하면 됩니다.
현재 시스템이 patch한 patch파일의 번호를 알기위해서는 showrev -p 명령을사용합니다. 다음은 그 예제입니다.
% showrev -p
Patch: 105393-01 Obsoletes: Requires: Incompatibles: Packages: SUNWcsu
Patch: 105518-01 Obsoletes: Requires: Incompatibles: Packages: SUNWcsu
Patch: 105615-03 Obsoletes: Requires: Incompatibles: Packages: SUNWcsu
.
.
.
Patch: 106125-02 Obsoletes: Requires: Incompatibles: Packages: SUNWswmt
Patch: 105407-01 Obsoletes: Requires: Incompatibles: Packages: SUNWvolu
%
가끔 patch를 설치하려고 하는데, checkinstall이 실패했다고 나오는 경우가 있습니다. Solaris 2.x에서 patch파일들은 nobody란 사용자가 읽을 수 있어야만 설치가 됩니다. patch파일을 푼 디렉토리의 모드를 확인하시고 nobody사용자가 읽을 수 없는 모드라면 다시 설정하시기 바랍니다.
Solaris 2.x에서 patch에 관한 내용은 http://night.i-land.net/~chang/src/lecture/patch/patch.html에서 박창민님이 잘 정리해 두셨습니다. 한번쯤 읽어보기를 권합니다.
2.27 SunOS 4.x의 passwd파일을 Solaris 2.x시스템에 맞게 고치려면?
SunOS 4.x까지는 계정관리를 위해 /etc/passwd파일을 사용했지만, Solaris 2.x부터는 /etc/passwd와 /etc/shadow파일을 함께 사용합니다. 따라서 SunOS 4.x에서 Solaris 2.x로 업그레이드를 했을때 계정을 관리하는 /etc/passwd를 /etc/passwd와 /etc/shadow파일로 바꾸어야 하는데 이때 사용하는 명령이 pwconv입니다. 단순히 pwconv라고 실행하면 바꿔줍니다.
Solaris 2.x를 사용하시는 분들중에 가끔 /etc/passwd파일에만 계정을 추가하고 pwconv 명령어를 사용하여 /etc/shadow파일을 갱신하는 분들도 계십니다.
2.28 /etc/passwd와 /usr/bin/passwd의 차이는 뭔가요?
/etc/passwd는 사용자의 정보(ID, UID, 홈디렉토리, shell, 주석등)의 정보가 들어있는 파일이고, /usr/bin/passwd는 /etc/shadow파일에 있는 사용자의 비밀번호를 변경할 때 사용하는 명령입니다.
/usr/bin/passwd는 SUID가 설정되어 있습니다. 왜냐하면 /usr/bin/passwd가 수정하는 /etc/shadow파일은 root만이 읽기/쓰기가 가능합니다. 따라서 일반 사용자가 자신의 비밀번호를 수정할 때 suid가 설정되어 있지 않다면 비밀번호의 변경이 불가능하겠죠? 다음은 제 시스템의 /usr/bin/passwd의 ls결과입니다.
$ ls -l /usr/bin/passwd
-r-sr-sr-x 3 root sys 96796 1997년 7월 16일 /usr/bin/passwd
일반적으로 /etc/passwd의 모드는 444로 되어있는데, 가끔 관리자중에는 일반사용자가 /etc/passwd파일을 읽지 못하도록 모드를 400로 변경하는 경우가 있습니다. 이경우 비밀번호의 변경등은 별 문제없이 가능하겠지만, ls의 경우 사용자이름이 아닌 UID로 출력하게 됩니다. 왜냐구요? UID를 사용자이름으로 바꾸지 못하니까요. :)
다른 시스템에서는 그렇지 않지만 Solaris 2.x에서는 특이하게도 /etc/passwd, /etc/group, /etc/hosts 의 내용들을 가지고 응용프로그램들에게 이름서비스를 해 주는 nscd라는 서버 프로그램이 있습니다. 이 프로그램때문에 /etc/passwd의 모드를 400로 해 두어도 UID가 아닌 사용자 이름이 나옵니다. 만일 nscd를 띄우지 않고 /etc/passwd등의 파일의 모드를 400로 한경우에는 UID만 나오게 됩니다.
2.29 NT와 Solaris의 비밀번호를 같이 관리하려면?
(이 부분은 제가 잘 몰라서 뉴스그룹에 올라온 몇가지 글들을 종합해 봅니다.) 우선 Solaris 2.6을 써야합니다. 그리고 Samba를 사용할 때 pam nt_dom이라는 모듈을 사용하시면 Solaris에서 NT의 비밀번호를 변경할 수 있습니다. 그리고 반대로 NT에서 Solaris의 비밀번호등을 관리하려면 Solstice Intranet Extension(Sun의 홈페이지를 보면 Solstice NFS Client 3.1라고 되어있습니다.) 프로그램을 NT에 설치하면 됩니다. 이 프로그램을 사용하면 Solaris가 NIS/NIS+를 사용하셔도 변경할 수 있습니다.
2.30 root 비밀번호를 잊었습니다.
CD-ROM으로 부팅하셔서 하드디스크의 /etc/shadow 파일의 비밀번호부분을 지우시면 됩니다. / 파티션이 /dev/dsk/c0t0d0s0인경우에 아래와 같은 작업을 하시면 됩니다.
ok boot cdrom -s
..
# mount /dev/dsk/c0t0d0s0 /mnt
# TERM=sun;export TERM
# vi /mnt/etc/shadow
# sync; reboot
2.31 /home에 파일을 쓰려면 어떻게 해야 하나요?
Solaris 2.x에서는 /home을 automounter가 mount해서 사용하기 때문에 root라 할지라도 디렉토리나 파일을 만들 수 없습니다. 하지만 실재로는 automounter를 쓰지 않는 경우에도 /home을 쓸 수 없다면 문제가 되겠죠? 이때 /home은 automount를 하지 않으려면 /etc/auto_master파일에서 /home부분을 주석처리 하면 됩니다.
2.32 계정을 만들 때 자동적으로 .cshrc와 .profile등의 파일을 만들려면?
/etc/skel 디렉토리에 복사하고 싶은 파일들을 만들어 두고 useradd나 admintool로 계정을 만들면 됩니다.
2.33 /etc/passwd파일에서 삭제를 했는데도 로긴이 가능합니다.
만일 NIS를 사용하시면 NIS에서 계정을 삭제하고, NIS map을 rebuild해줘야 합니다.자세한 내용은 NIS의 메뉴얼을 참조하세요.
2.34 passwd를 실행했는데 없는 ID라고 나옵니다.
/etc/shadow나 /etc/passwd의 정보가 잘못되었을때, 비밀번호를 변경하기 위해 passwd를 실행하면 아래와 같은 메세지가 나옵니다.
% passwd
passwd: Changing password for id
passwd(SYSTEM): id does not exist
권한이 거부됨
%
따라서 이 두개의 파일을 찬찬히 살펴보신 후 필요없는 라인이 추가되지 않았는지 아니면 계정에 들어갈 수 없는 글자가 있지는 않은지 확인해 보시기 바랍니다.
2.35 package란 뭔가요?
package는 원래 SVR4에서 프로그램의 설치와 삭제등을 쉽게하기 위해서 필요한 파일을 묶어둔 것을 말합니다. 하지만 주로 Solaris에서 프로그램의 배포에 사용되는 형식을 지칭합니다.
package를 구할 수 있는 가장 대표적인 곳으로 ftp://sunsite.unc.edu/pub/solaris와 http://sunfreeware.com이 있습니다. 전자에서는 몇가지 대표적인(gcc등) 패키지와 sunfreeware에서 배포하는 패키지를 미러링하고 있습니다. 국내에서는 대표적으로 ftp://ftp.kreonet.re.kr/pub/Sun/binaries와 ftp://sunsite.snu.ac.kr/pub/packages/sun_binary에서 미러링을 하고 있습니다. 이 곳에는 sparc와 i86pc 디렉토리가 있는데, 각각 sun의 sparc용 solaris와 solaris for x86용 package들이 있습니다. 그리고 freeware 디렉토리에는 후자에서 배포되는 package들이 있습니다.
package를 설치할 때는 pkgadd라는 명령을 사용하면 됩니다. 사용방법은 pkgadd -d 디렉토리명 pkg명입니다. 일반적으로 자주 설치하는 패키지인 ftp://sunsite.unc.edu/pub/solaris/sparc/GNUgcc.2.8.1.SPARC.Solaris.2.6.pkg.tgz의경우 다음과 같이 입력하면 설치됩니다.
% gzip -d GNUgcc.2.8.1.SPARC.Solaris.2.6.pkg.tgz
% tar -xf GNUgcc.2.8.1.SPARC.Solaris.2.6.pkg.tar
% pkgadd -d .
가져온 패키지들을 gzip와 tar로 풀면 각각 디렉토리가 만들어지고, 필요한 파일들이 그 디렉토리에 들어갑니다. 그리고 pkgadd명령을 실행하면 설치가능한 패키지들이 나열됩니다.(만일 디렉토리는 분명히 있지만 화면에 나열되지 않는다면 패키지의 디렉토리의 소유권이 적당한지 확인해 보시기 바랍니다.) 사용자가 원하는 번호를 입력하면 설치를 시작합니다.일반적인 패키지의 설치과정이 위와 같지만, 가끔 뉴스그룹으로 질문을 하시는 분들중에 http://sunfreeware.com에서 받아온 패키지의 경우에는 디렉토리가 만들어 지지 않고 pkgadd -d . 를 해도 화면에 나오지 않기때문에 질문하시는 분이 많습니다. 이때는 pkgadd -d 파일명 을 입력하시면 됩니다. 간단하게 예를들어 보죠.
% gzip -d bison-1.24.gz
% pkgadd -d bison-1.24
위와 같이 간단하게 입력하면 설치하실 수 있습니다.
참고로 http://sunfreeware.com에서 가져온 패키지들은 특별한 언급이 없는한 /opt에 설치됩니다. 그에비해 sunsite에서 가져온 패키지들은 일반적으로 /usr/local에 설치됩니다.
2.36 CDE는 뭔가요?
CDE(Common Desktop Environment) (아직 추가하지 못했습니다. 죄송합니다.)
CDE는 Solaris 2.6이라면 OS에 포함되어 있고, 그 이하 버전이면 OS와 같이 들어있는 CD-ROM에서 구할 수 있습니다. 만일 CD-ROM에 없거나, CD가 없을경우에는 ftp://sunsolve.sun.com/pub/cde/ 에서 받을 수 있습니다. 이 디렉토리에 가시면 파일이 여러가지가 있습니다. 파일이름중에 dev가 들어간 것은 developer를 의미하며 ab가 들어간 것은 answerbook이 포함되어있다는 의미입니다.
2.37 CDE로긴(dtlogin)의 설정은 어떻게 하나요?
다음과 같은 문제를 생각해 보죠.
처음 CDE를 설치할 때 영문으로 설치를 했습니다. 나중에 한글환경을 쓰려고 CDE에서 ko로 설정을 했는데 한번뿐이고 다시 로그아웃을 하면 영문으로 돌아갑니다. CDE의 기본언어를 설정하려면 어떻게 하면 되나요?
이경우 여러가지 방법이 있지만 다음의 방법을 이용해 보세요. 우선 /etc/dt/config디렉토리를 만듭니다. (만일 디렉토리가 있다면 만들지 마세요.) 그다음 /usr/dt/config/Xconfig를 만든 디렉토리로 복사합니다. (/usr/dt/config/Xconfig는 수정하시면 안됩니다.) 그리고 /etc/dt/config/Xconfig중에서 Dtlogin*language의 값을 ko로 바꾸시고 저장할 후에 dtconfig -reset을 실행하면 됩니다.
또한 CDE를 설치하면 기본적으로 dtlogin이 뜹니다. 이 화면대신에 원래 로긴화면을 사용하려면 dtconfig -d 와 같이 입력하시면 됩니다. 만일 CDE로긴화면이 뜨게 하려면 dtconfig -e 와 같이 입력하시면 됩니다.
2.38 부팅할 때 마다 어떤 일을 수행하려면 어떻게 하나요?
Solaris는 /etc/rcX.d(X는 S, 0, 1, 2, 3)에서 필요한 스크립트를 수행합니다. 만일 Single User모드로 부팅했다면 /etc/rcS.d에 있는 파일들을, 보통때는 모두다 수행합니다. 따라서 이들중 한 디렉토리에 SXXfilename(XX는 원하는 두자리 숫자, filename은 임의의 이름)이라는 파일을 만들고, shell script형태로 적어주면 됩니다. rc 프로세스는 숫자가 작은 스크립트부터 차례로 수행해 줍니다. (파일을 만들때는 단순히 명령어만 적어도 되지만, 다른 파일을 참조해서 만들기 바랍니다.)
그리고 SunOS 4.1.x에서는 /etc/rc.* 파일에 적어넣어면 됩니다. 일반적으로 rc.local에 적는 경우가 많습니다.
2.39 부팅시 마운트되는 순서는?
가장 먼저 /와 /usr는 읽기전용으로 마운트합니다. 이때 문제가 있다면 커널이 이 두개의 파티션에 대해 fsck를 수행합니다. 그리고 문제가 없다면 두번째로 swap을 마운트합니다. 세번째로 /와 /usr를 쓰기가 가능하도록 다시 마운트합니다. 그 이후에 /usr/platform, /proc, /dev/fd등을 차례대로 마운트합니다.
/etc/vfstab을 보면 / /usr /var 파일시스템은 mount at boot항목이 no로 되어있습니다. 따라서 이 파티션이 언제 마운트되는지 궁금해 하시는 분들이 많은데, / /usr /var는 부팅과정에 필요한 파티션이기 때문에 커널이 미리 마운트합니다. 그래서 /etc/vfstab에서는 no로 설정이 되어 있는것입니다.
2.40 다른 시스템의 X Window 프로그램을 수행하고 싶습니다.
디스플레이를 사용하는 시스템에서 xhost로 프로그램이 있는 시스템을 적어주고, 프로그램이 있는 시스템의 DISPLAY환경변수를 수정하면 됩니다. 만일 A가 현재 사용하는 컴퓨터(X Server)이고 B가 응용프로그램이 있는 컴퓨터라면 아래와 같이 입력하면 됩니다. (csh를 사용한다고 가정)
[A]% xhost + B
[A]% telnet B
[B]% setenv DISPLAY A:0.0
[B]% 응용프로그램
2.41 로컬시스템의 X 프로그램을 실행했는데 display를 열수없다고 합니다.
같은 시스템이더라도 telnet이나 su로 한번 거쳐서 접속한 경우에는 아래와 같은 에러가 발생합니다.
Error: Can't open display: unix:0
이때는 su나 telnet전에 xhost + localhost등을 입력해 주고, su나 telnet후 DISPLAY환경변수를 localhost:0.0으로 설정하시면 됩니다.
2.42 libX11.so.6.1이 없다고 에러가 납니다.
Solaris 2.6이라면 openwindow가 X11R6를 지원합니다. 따라서 /usr/openwin/lib/libX11.so.4 를 가리키는 libX11.so.6.1을 만들면 됩니다.
Solaris 2.5.1 이하라면 시스템의 버젼에 맞는 X11R6 패키지를 설치하시면 됩니다.
혹 LD_LIBRARY_PATH가 적절히 설정되지 않은경우도 있습니다. 이 환경변수도 확인해 보시기 바랍니다. 참고로 LD_LIBRARY_PATH는 동적라이브러리(libX11.so.6등의 라이브러리)가 있는 디렉토리들을 지정하고 있습니다. 만일 /usr/local/X11R6/lib를 추가하고 싶다면 아래와 같이 입력하면 됩니다.(csh이라고 가정)
setenv LD_LIBRARY_PATH $LD_LIBRARY_PATH:/usr/local/X11R6/lib
2.43 최근 login한 사람들에 대한 정보를 알수 없나요?
사용자들이 login하면 그 정보가 /var/adm/utmp에 저장됩니다. 이 파일에 저장된 내용을 출력해주는 프로그램이 /usr/bin/last입니다. 그리고 참고적으로 /var/adm에는 utmp, utmpx, wtmp, wtmpx가 있는데 utmp, wtmp는 같은 파일이고 utmpx, wtmpx는 utmp의 확장파일입니다. 만일 어떤 사용자의 최근 접속상황을 보려면 last id라고 하시면 됩니다.
utmp, wtmp, lastlog등은 사용자가 시스템에 접속했을 때 로그가 기록되는 파일로 /usr/bin/login프로그램에 의해 만들어집니다. 만일 만들고 싶지 않다면 login프로그램을 수정(?)하시든지, 아니면 주기적으로 지워주는 방법밖에 없습니다. 주기적으로 지워줄때는 cron등을 이용하시면 편리합니다. 그리고 아예 만들지 않으려면 wtmpx등의 파일을 /dev/null의 링크파일로 만드는 방법이 있습니다.
2.44 syslogd는 어떤 역활을 하나요?
언제, 어디서, 누가, 어떤 서비스를 통해서 시스템에 접속을 시도했는지를 기록해주는 서버입니다. 대표적으로 telnet, ftp, mail등에 대한 로그를 만들어줍니다. 그리고 syslogd에 대한 설정파일은 /etc/syslog.conf입니다. syslogd에 의해 만들어진 log파일은 /var/log에 생성됩니다.
/etc/hosts에 보면 loghost라는 부분이 있습니다. 이 부분은 syslogd에 의해 사용됩니다. (추가설명 필요)
2.45 cron이 실행되지 않습니다.
crontab에 등록하려고 하니 다음과 같은 메세지가 나옵니다. 이런경우에는
cron may not be running - call your system administrator
warning: commands will be executed using /usr/bin/sh
cron을 사용하려면 cron.allow에 등록이 되어있어야 합니다. 첫번째 메세지는 cron.allow에 등록이 되어있지 않기 때문에 생기는 메시지입니다. 그리고 cron은 /bin/sh를 기본쉘로 사용하지만 /bin이 /usr/bin에 링크되어있기 때문에 두번째와 같은 에러가 출력됩니다. 따라서 두번째 메시지는 무시하셔도 됩니다.
2.46 Solaris 2.x에서 시스템의 최대값을 알려면?
Solaris 2.x에서 시스템의 maximum값(maximum filesize, maximum stacksize 등등)은 ulimit를 사용하면 알 수 있습니다. 이 값을 바꾸려면 /etc/system파일에 합니다. 다음은 사용자당 사용할 수 있는 최대 프로세스갯수와 시스템의 최대 프로세스갯수를 설정하는 예제입니다.
set maxuprc=512
set max_nprocs=1024
시스템의 메시지큐 크기를 변형하려면/etc/system 에 msginfo_msgmnb xxx 와 같이 (xxx는 큐의 크기) 적으면 됩니다.
2.47 Solaris에서 hostid를 변경하려면?
host ID는 변경할 수 없습니다.(원칙) 하지만 가끔 변경하는 프로그램이 나오곤 하죠.(Solaris 2.5의 hid2, SunOS 4.1.3의 sethostid 등) hid2는 ftp://ftp.mindlink.net/pub/crypto/sun-stuff/change-sun-hostid.tar.gz에서 구할 수 있습니다.
2.48 Solaris 2.x는 y2k에 안전한가요?
http://www.sun.com/y2000에 가시면 Sun제품의 y2k 에 관한 내용을 알 수 있습니다. 일반적으로 Recommended Patch를 설치하고, y2k Patch를 설치하시면 됩니다.
2.49 TT_DB/ 디렉토리는 뭔가요?
Solaris의 서비스중에 rpc.ttdbservd가 TT_DB 디렉토리에 데이터베이스를 생성, 삭제합니다. 따라서 rpc.ttdbservd를 띄우지 않는다면, 삭제하셔도 됩니다. (박창민님)
2.50 Solaris 2.6에서 2GB이상의 파일을 사용하려면?
Solaris 2.6에서 프로그램이 2GB이상의 파일을 지원하려면 2.6에서 아래의 옵션을 사용하여 컴파일해야 합니다. (이석찬님)
CFLAGS = "`getconf LFS_CFLAGS`"
DEFS = -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64
LDFLAGS = "`getconf LFS_LDFLAGS` -s"
LIBS = "`getconf LFS_LIBS`"
따라서 Solaris 2.6이 아닌 시스템에서 컴파일된 프로그램은 위의 옵션을 사용하여 다시 컴파일 하셔야 합니다.
2.51 talk에서 한글을 쓰려면?
LANG환경변수를 ko로 설정하고, /usr/SUNWale/bin/talk를 사용하면 됩니다.
2.52 비밀번호 없는 계정을 만들려면?
SunOS 4.x까지는 /etc/passwd에 비밀번호란을 지우면 되지만, Solaris 2.x에는 비밀번호를 관리하는 /etc/shadow의 비밀번호란을 지워도 로긴하면 다시 입력하게 되어있습니다. 이때 로긴시 비밀번호를 입력하지 않도록 하려면 /etc/default/login에서 PASSREQ=NO로 만들면 됩니다.
2.1 루트파티션의 용량을 작게 잡아서 가득찼습니다.
여러가지 방법이 있습니다. 가장 확실한 방법은 충분한 여유가 있는 하드디스크를 붙여서 부트디스크를 복사하는 방법입니다. 하지만 이 방법은 성공하기가 힘든(?) 단점이 있습니다. 임시방편으로는 몇개의 디렉토리를 다른 파티션으로 옮기고 링크를 만드는 방법이 있습니다. 이때 많이 애용(?)되는 파티션으로 /var가 있습니다. /var전체나 /var안에서 디스크를 많이 차지하는 파티션을 다른곳으로 옮기고 링크를 만들어 주면 됩니다. (절대 /sbin이나 /etc같은 디렉토리를 옮기지 마세요. ^_^)
2.2 하드디스크 파티션은 어떻게 잡는게 좋나요?
개인적 취향(?), 사용하는 응용프로그램에 따라 다릅니다. 아래는 안진수님이 뉴스그룹에 올려주신 내용입니다.(참고하세요.)
/ 64MB
/usr 400MB 이상 (최경렬님은 최소 600MB이고, 보통 1GB이상을 잡는게 좋다고
메일을 보내주셨습니다.)
/var 128MB 이상 (Recommended Patches를 설치하려면 적어도 100MB가
필요합니다.)
swap 물리적 메모리의 2배에서 4배
/opt 400MB 이상
/usr/local 분리권장
저도 위와 비슷하게 파티션을 나누고 대부분의 프로그램은 /usr/local이나 /opt에 설치합니다.
2.3 swap영역이 모자라는데 어떻게 추가할 수 있나요?
Solaris 2.x에서는 초기에는 따로 파티션을 잡아서 swap영역을 사용하지만 나중에 추가할 경우 swap파일을 만들어서 추가합니다. 이때 사용하는 명령어가 mkfile 입니다. 만일 /opt/swap이라는 200MB짜리의 파일을 만들어서 swap영역으로 쓰고 싶다면 아래와 같이 파일을 만들고 swap명령어로 추가할 수 있습니다.
% mkfile 200m /opt/swap
% swap -a /opt/swap
만일 항상 사용할 swap영역이라면 /etc/vfstab에 추가하면 됩니다. 다음은 /opt/swap을 추가한 /etc/vfstab의 예제입니다.
% cat /etc/vfstab
.
.
swap - /tmp tmpfs - yes -
/opt/swap - - swap - no -
%
2.4 inode full이 나옵니다.
파일시스템에서 사용하고 있는 inode를 모두 사용했기 때문입니다. 이렇게 되면 더 이상의 파일을 생성할 수 없습니다. 파일들을 백업한 후(문제가 되는 파일 시스템만 백업하면 됩니다.) newfs의 -i옵션을 사용하여 inode의 갯수를 늘이고 백업한 파일들을 복구해야 합니다.
2.5 사용자마다 특정크기만큼만 하드디스크를 할당하는 방법이 있을까요?
Solaris 2.x라면 quota를 설정하시면 됩니다. quota를 설정하는 방법은 Solaris메뉴얼중 System Admin Guide Vol2에 보시면 잘 나와있습니다. How to enable user storage space quotas for Solaris in a mounted file system 간략하게 설명드리면 아래와 같습니다.
/etc/vfstab에서 quota를 설정하고자 하는 파일시스템의 마운팅 옵션에 rq를 지정한다.
$ cat /etc/vfstab
..
/dev/dsk/c0t2d0s6 /dev/rdsk/c0t2d0s6 /home ufs 1 yes rq
..
quota를 설정할 파일시스템에 quotas라는 파일을 만든다.
$ touch quotas
$ chmod 600 quotas
각 사용자에게 quota를 할당하기 위하여 edquota라는 명령을 사용한다.
$ edquota louis
fs /home blocks (soft = 0, hard = 0) inodes (soft = 0, hard = 0)
여기에서 할당하고자 하는 양만큼 soft와 hard부분에 적어준다. 만일 20MB를 할당하려면 아래와 같이 해준다. (만일 quota를 제거하고자 한다면 0을 적어주면 된다.)
fs /home blocks (soft = 20000, hard = 20000) inodes (soft = 0, hard = 0)
만일 다수의 사용자에게 같은 양의 quota를 할당하려면 하나의 사용자만 할당하고 복사할 수 있는데 아래는 louis 사용자의 quota설정을 aaa, bbb, ccc 사용자에게도 똑같이 할당하는 예제이다.
$ edquota -p louis aaa bbb ccc
2.6 cachefs가 뭔가요?
http://white.ce.kyungpook.ac.kr/~louis/papers/cachefs/를 읽어보세요. 설명과 기본적인 설치법이 적혀 있습니다.
2.7 네트웍으로 root접속이 가능하게 하려면?
기본적으로 Solaris 2.x에서는 네트웍으로 접속하고 root로 로긴하면 아래와 같은 메세지를 출력하고 접속이 안됩니다.
login: root
Password:
Not on system console
Connection closed by foreign host.
Solaris 2.x는 기본적으로 root사용자는 console에서만 로긴이 가능합니다. (su는 제외) 이것을 console이외에서도 가능하게 하려면 /etc/default/login에서 CONSOLE=/dev/console에 주석을 달면 됩니다.
참고로 CONSOLE=/dev/console의 의미는 root는 /dev/console에서만 login이 가능하다는 의미입니다. 만일 root사용자로 로긴이 불가능하게 하려면 CONSOLE= 와 같이 해 두면 됩니다. (하지만 이 설정은 기본적으로 설치된 in.telnetd등에만 해당됩니다. 만일 ssh등을 사용한다면 이 파일과 상관없이 root계정으로 로긴이 가능합니다.)
2.8 로긴화면에서 나오는 메시지를 바꾸려면?
telnet으로 접속시 UNIX(r) System V Release 4.0 (white) 같은 메세지를 바꾸고 싶다면 Solaris 2.6의 경우 /etc/default/telnetd에서 BANNER 항목을 수정하면 되지만, 그 이외의 시스템에서는 특별한 방법이 없습니다. 몇분들의 말을 따르자면 binary파일(in.telnetd)을 수정하면 가능하다고 하더군요 :)
콘솔에서의 white console login: 메시지는 /etc/inittab에서 수정할 수 있습니다. 기본적으로 "`uname -n` console login: "으로 되어있습니다.
로긴화면에 여러줄의 내용을 출력하려면 /etc/issue에 적어주면 됩니다. 그리고 로긴후 여러줄의 내용을 출력하려면 /etc/motd에 적어주면 됩니다.
로긴후 나오는 메시지들(motd내용, 최근접속일등)을 나오지 않게 하려면 $HOME/.hushlogin 을 만들면 나오지 않습니다. (touch $HOME/.hushlogin)
2.9 한번만 접속을 하면 같은 이름으로 로긴을 막고싶습니다.
기본적으로 지원해 주는건 아니지만 /etc/profile이나 /etc/.login에서 간단한 script를 써서 구현할 수는 있습니다. 또한 Michael P. Crider가 만든 idled를 사용하셔도 됩니다. idled는 http://www.darkwing.com/idled/README.html에서 구할 수 있습니다.
2.10 floppy드라이버를 사용하려면 어떻게 해야 하나요?
Solaris 2.x에서는 vold(Volume Management Daemon)을 이용해서 floppy나 CD-ROM을 마운트합니다. 따라서 floppy를 사용할때는 드라이버에 디스켓을 넣고, volcheck명령어를 실행하면 마운트가 됩니다. 보통 /floppy/floppy0에 마운트가 됩니다. 그리고 디스켓은 MS-DOS 포맷으로 되어있어도 문제가 없이 마운트됩니다. 그리고 다 쓰고 났을때는 eject floppy를 입력하면 floppy가 빠져나오며 자동으로 마운트가 풀립니다.
2.11 CD-ROM드라이버를 이용하려면 어떻게 하나요?
Solaris 2.x에서는 floppy와 마찬가지로 vold를 이용해서 마운트합니다. 현재 vold가 수행중일때는 CD-ROM의 경우에는 CD를 삽입하기만 하면 자동으로 /cdrom에 마운트가 되고, CD를 빼고 싶을때는 CD-ROM드라이버에 있는 버튼을 누르거나, eject cdrom이라는 명령어를 입력하면 됩니다. (가끔 CD-ROM 드라이버의 버튼을 눌렀을 때 CD가 빠져나오지 않는경우가 있습니다. 이때는 eject cdrom 이라고 입력하면 잘 빠져나옵니다.) 참고로 vold의 설정파일 은 /etc/vold.conf이며, 자세한 사항은 vold(1M)의 메뉴얼을 참조하시기 바랍니다.
2.12 다른 시스템의 CD-ROM드라이버를 이용하려면?
만일 두대의 컴퓨터 A, B가 있는데, A에는 CD-ROM 드라이버가 있고, B에는 없어서 B에서 A의 CD-ROM 드라이버를 이용하고 싶다면, A에서는 /etc/rmmount.conf 의 마지막에 아래와 같이 추가하고 vold 데몬을 다시 실행한 후
share cdrom* -o ro=B
B에서는 /cdrom에 사용하고 싶다면
% ln -s /net/A/cdrom /cdrom
와 같이 연결해 두시면 됩니다.
참고로 Solaris에서는 CD-ROM이나 floppy등은 vold(1M)가 관리합니다. 만일 어떤 사용자가 CD를 넣으면 vold는 그 일을 감지하고 rmmount(1M)를 호출해서 다시 마운트해줍니다. rmmount(1M)는 CD나, floppy와 같은 장치들을 마운트할 때 사용하는데, 그 설정파일은 /etc/rmmount.conf입니다. 자세한 내용은 rmmount.conf와 rmmount의 메뉴얼을 참조하세요.
2.13 Sun용 CD-ROM드라이버가 따로 있나요?
따로 있지는 않습니다. Sun에서는 SCSI CD-ROM드라이버중 버퍼가 512K바이트인 것만 지원합니다. 잘 돌아가는 모델에는 소니의 경우 CDU-8012모델(Sun 1배속 CD-ROM드라이버), 도시바의 4101TA모델(Sun 2배속 CD-ROM드라이버), 3301B모델, 3401B모델, 애플의 CD 300i가 있으며, 플랙스터의 CD-ROM드라이버의 경우 대부분 잘 돌아갑니다. 만일 구입을 하신다면 플랙스터의 모델을 구입하시는것이 좋습니다.(최경렬님, 이석찬님)
2.14 새로운 장치를 달고 device file을 만들려면?
일단 다른 주변장치와 충돌하지 않는 SCSI번호(CD-ROM드라이버는 일반적으로 6번을 사용하고, Tape드라이버는 일반적으로 4번을 사용합니다.)를 할당하고, PROM prompt에서 probe-scsi명령으로 정상적으로 인식이 되는지 확인합니다. 여기에서 잘 나오면 boot -r명령으로 /dev와 /devices의 파일들을 갱신하면 됩니다.
ok probe-scsi
ok boot -r
보통 외장형 Tape드라이버를 달고 이 작업을 수행하는데 이때 생기는 장치파일은 Solaris 2.x의 경우 /dev/rmt/0 (SCSI 4번을 쓴경우), /dev/rmt/1 (SCSI 5번을 쓴 경우)이며, SunOS 4.x의 경우에는 /dev/rst0, /dev/rst1이 생깁니다.
2.15 Tape의 내용을 삭제하려면?
Tape의 내용을 삭제하려면 mt명령을 사용하시면 됩니다. 만일 Tape드라이버의 장치파일이름이 /dev/rmt/0 라면 아래와 같이 입력하시면 됩니다.
$ mt -t /dev/rmt/0 erase
2.16 Workstation의 화면 해상도와 색상수를 바꾸려면?
Sun Workstations의 경우 화면해상도와 색상수등을 변형하려면 사용하는 Video Card가 framebuffer를 지원해야 합니다. 보통 Creator 3D에서는 사용가능합니다. 만일 콘솔의 해상도를 1280x1024로 변경하려면 PROM prompt에서 다음과 같이 입력하면 됩니다.
ok setenv output-device screen:r1280x1024x64
ok reset
이렇게 PROM prompt뿐만 아니라 ffbconfig 프로그램을 이용할 수 있습니다.
만일 Solaris x86에서 화면 해상도를 바꾸려면, kdmconfig 명령을 이용해서 화면해상도를 변경할 수 있습니다. Solaris x86에서 화면해상도를 변경하기 전에 현재 사용하고 있는 Graphic Adapter가 Solaris x86에서 지원하는지를 확인한 후 실행하시기 바랍니다. (신제철님)
색상수를 16bit색상으로 바꾸려 할때, openwin을 사용하신다면, openwin -dev framebuffer 장치파일명 defdepth 16 과 같이 하시고, CDE를 사용하시면 /usr/dt/config/Xconfig 파일에 Xsun -dev framebuffer 장치파일명 defdepth 16 과 같이 설정하시면 됩니다. 제가 사용하는 Creator 3D의 경우엔 framebuffer 장치파일명이 /dev/ffb0 입니다. (당연히 framebuffer가 원하는 색상수를 지원해야 합니다.)
2.17 Solaris 2.x에서 두 개이상의 Network Adapter를 설치하려면?
Network Adapter를 달고, /etc/hostname.hme?,/etc/hostname.le? (100M Network Adapter이면 hme0, hme1, .. 10M Network Adapter이면 le0, le1, ..)에 각 Adapter의 호스트이름을 작성하고, /etc/hosts에 IP Address를 설정하면 사용할 수 있습니다.
2.18 프린터를 병렬포트에 연결하려면?
Sun Workstation의 병렬포트는 시스템의 종류에 따라 다릅니다. 일단 병렬포트가 있는지 확인하시고 (그림에 // 와 같이 그려진 부분이 병렬포트입니다.) 형태에 맞는 병렬케이블을 구입해서 사용하시면 됩니다.
2.19 모뎀을 달려면?
ftp://sunsite.snu.ac.kr/pub/sun-info/sun-faq/FAQs/Solaris2.x-Modem-and-Terminal-Setup을 참고하세요.
2.20 Postscript파일을 출력하려면?
postscript을 지원하지 않는 대부분의 프린터에서 postscript파일을 출력하려면 gs(ghost script)를 사용하면 됩니다. 그리고 postscript를 지원하는 프린터일 경우에도 한글파일들을 출력하려면 gs를 사용하시는게 좋습니다.
gs를 필터로 사용하는 방법은 http://cfauvcs5.harvard.edu/SetGSprinter4Solaris.html를 참고하시기 바랍니다.
그리고 잉크젯 프린터를 이용하여 Color로 출력하려면 해당 프린터의 gs dev파일을 구하셔서 gs를 재 컴파일 하면 됩니다. stylus color프린터는 dev파일이 기본적으로 들어있으므로 컴파일이 Makefile의 DEVICE_DEVS에 stcolor.dev를 추가하면 됩니다. HP의 잉크젯은 http://www.erdw.ethz.ch/~bonk/hp850/hp850.html에서 dev파일을 구할 수 있습니다.
2.21 네트웍을 지원하는 프린터를 설치하려면?
HP의 제품인 경우 HP의 홈페이지에서 JetAdmin을 받아 패키지를 설치한 후 (/usr/hpnp에 설치한 경우) /usr/hpnp/jetadmin으로 프린터를 추가하면 됩니다. 물론 IP와 Netmask등은 설정해 두셔야 합니다. (서진수님)
2.22 JAZZ드라이버나 ZIP드라이버를 달려면?
JAZZ드라이버나 Zip드라이버는 SCSI를 사용하는경우 일반 디스크처럼 사용하실 수 있습니다. 단지 주의하셔야 할 내용은 미디어를 뽑기전에 umount를 하셔야 합니다.
2.23 백업 하려면?
여러 가지 명령어가 있지만, 가장 기본적인 tar에 대해 말씀드리겠습니다. 만일 /home 디렉토리 이하의 파일들을 /dev/rmt/0에 백업받으려 한다면 다음과 같이 입력하시면 됩니다.
% tar cvf /dev/rmt/0 /home
나중에 백업한 내용을 restore하시려면 /에서 다음과 같이 입력하면 됩니다.
% tar xvf /dev/rmt/0
tar를 사용하는경우 원하는 파일만을 restore하려면 아래와 같이 사용하시면 됩니다. (man tar에서 가져옴)
% tar xvf /dev/rmt/0 `tar tf /dev/rmt/0 | grep 'pattern'`
이 외에도 restore하고자 하는 파일의 리스트를 파일로 만들고(e.g list), 다음과 같이 사용하셔도 됩니다.
% tar xvf /dev/rmt/0 -I list
2.24 Solaris 2.x에서 /dev/rmt/에 있는 장치파일들의 의미
Solaris 2.x에서 Tape드라이버를 달고 device파일들을 만들고 나면 /dev/rmt/디렉토리에 많은 파일들이 생깁니다. 이 파일들은 그 이름에 따라 Tape을 사용하는 방법이 다른데 간단하게 알아보면 일반적으로 파일명은 아래와 같이 생겼습니다.
#[lmhc][b][n] (#는 숫자)
l,m,h,c는 기록밀도입니다. 각각 low, medium, high, compress를 의미합니다. 단순히 장치파일만 생겼다고 모두 지원하는건 아닙니다. compress를 지원하는 드라이버가 있고, 아닌 드라이버가 있습니다. 그리고 b는 BSD호환의 의미이며, n은 no-rewind의 의미입니다. 따라서 n이 없는 장치파일을 이용해서 백업을 하면 백업이 끝난 후 rewind를 하지만, n이 붙은 장치파일을 이용하여 백업을 하면 rewind를 하지 않습니다. 따라서 하나의 장치에 여러개의 볼륨을 백업하려면 n이 붙은 장치명을 사용해야 합니다.
2.25 다른 시스템의 테잎 드라이버를 이용하려면?
여러가지 방법이 있겠지만, 가장 간단한 방법은 rsh를 이용하는 방법입니다. 먼저 테입드라이버가 있는 시스템에 .rhosts파일을 만들어서 다른 시스템에서 rsh로 접속할 수 있게 한후 테입드라이버가 없는 시스템에서 다음과 같이 입력하시면 백업할 수 있습니다.
% tar cvf - [파일들] | rsh [테입드라이버가 있는 시스템] dd of=/dev/rmt/0
만일 테입으로 부터 파일을 풀려고 하면 아래와 같이 입력하시면 됩니다.
% rsh [테입드라이버가 있는 시스템] dd if=/dev/rmt/0 | tar xvf -
2.26 patch가 뭔가요?
Sun Microsystems에서 처음 Solaris등의 프로그램을 배포한 후 그 이후에 발견되는 버그들에 대해 수정한 파일을 patch파일이라고 합니다. 만일 105393번을 patch하라고 한 경우 105393이 patch번호입니다. 위와 같은 경우 105393번 patch파일을 구해와서 patch해주면 됩니다.
patch중에는 일반 patch파일과 recommended patch가 있는데, recommended patch는 이름에서 알 수 있는 것 처럼 추천하는 patch입니다. 운영체제나 프로그램의 보안상의 버그등 중요한 내용이므로 반드시 patch해주는 것이 좋습니다.
Sun Microsystems에서 patch파일을 배포하는 장소는 ftp://sunsolve.sun.com/pub/patches이고, 국내에서도 여러곳에서 미러링을 하고 있습니다. 대표적인 곳으로 ftp://sunsite.snu.ac.kr/pub/sun-info/sun-patches와 ftp://ftp.kreonet.re.kr/pub/Sun/sun-info/sun-patches가 있습니다. 가까운 곳에서 patch파일을 가져오시면 됩니다.
patch파일을 설치하는 방법은 patch파일의 README에 잘 설명이 되어있습니다. 일반 patch파일의 경우 압축을 풀고 디렉토리에 있는 installpatch를 root권한으로 실행하면 됩니다.
현재 시스템이 patch한 patch파일의 번호를 알기위해서는 showrev -p 명령을사용합니다. 다음은 그 예제입니다.
% showrev -p
Patch: 105393-01 Obsoletes: Requires: Incompatibles: Packages: SUNWcsu
Patch: 105518-01 Obsoletes: Requires: Incompatibles: Packages: SUNWcsu
Patch: 105615-03 Obsoletes: Requires: Incompatibles: Packages: SUNWcsu
.
.
.
Patch: 106125-02 Obsoletes: Requires: Incompatibles: Packages: SUNWswmt
Patch: 105407-01 Obsoletes: Requires: Incompatibles: Packages: SUNWvolu
%
가끔 patch를 설치하려고 하는데, checkinstall이 실패했다고 나오는 경우가 있습니다. Solaris 2.x에서 patch파일들은 nobody란 사용자가 읽을 수 있어야만 설치가 됩니다. patch파일을 푼 디렉토리의 모드를 확인하시고 nobody사용자가 읽을 수 없는 모드라면 다시 설정하시기 바랍니다.
Solaris 2.x에서 patch에 관한 내용은 http://night.i-land.net/~chang/src/lecture/patch/patch.html에서 박창민님이 잘 정리해 두셨습니다. 한번쯤 읽어보기를 권합니다.
2.27 SunOS 4.x의 passwd파일을 Solaris 2.x시스템에 맞게 고치려면?
SunOS 4.x까지는 계정관리를 위해 /etc/passwd파일을 사용했지만, Solaris 2.x부터는 /etc/passwd와 /etc/shadow파일을 함께 사용합니다. 따라서 SunOS 4.x에서 Solaris 2.x로 업그레이드를 했을때 계정을 관리하는 /etc/passwd를 /etc/passwd와 /etc/shadow파일로 바꾸어야 하는데 이때 사용하는 명령이 pwconv입니다. 단순히 pwconv라고 실행하면 바꿔줍니다.
Solaris 2.x를 사용하시는 분들중에 가끔 /etc/passwd파일에만 계정을 추가하고 pwconv 명령어를 사용하여 /etc/shadow파일을 갱신하는 분들도 계십니다.
2.28 /etc/passwd와 /usr/bin/passwd의 차이는 뭔가요?
/etc/passwd는 사용자의 정보(ID, UID, 홈디렉토리, shell, 주석등)의 정보가 들어있는 파일이고, /usr/bin/passwd는 /etc/shadow파일에 있는 사용자의 비밀번호를 변경할 때 사용하는 명령입니다.
/usr/bin/passwd는 SUID가 설정되어 있습니다. 왜냐하면 /usr/bin/passwd가 수정하는 /etc/shadow파일은 root만이 읽기/쓰기가 가능합니다. 따라서 일반 사용자가 자신의 비밀번호를 수정할 때 suid가 설정되어 있지 않다면 비밀번호의 변경이 불가능하겠죠? 다음은 제 시스템의 /usr/bin/passwd의 ls결과입니다.
$ ls -l /usr/bin/passwd
-r-sr-sr-x 3 root sys 96796 1997년 7월 16일 /usr/bin/passwd
일반적으로 /etc/passwd의 모드는 444로 되어있는데, 가끔 관리자중에는 일반사용자가 /etc/passwd파일을 읽지 못하도록 모드를 400로 변경하는 경우가 있습니다. 이경우 비밀번호의 변경등은 별 문제없이 가능하겠지만, ls의 경우 사용자이름이 아닌 UID로 출력하게 됩니다. 왜냐구요? UID를 사용자이름으로 바꾸지 못하니까요. :)
다른 시스템에서는 그렇지 않지만 Solaris 2.x에서는 특이하게도 /etc/passwd, /etc/group, /etc/hosts 의 내용들을 가지고 응용프로그램들에게 이름서비스를 해 주는 nscd라는 서버 프로그램이 있습니다. 이 프로그램때문에 /etc/passwd의 모드를 400로 해 두어도 UID가 아닌 사용자 이름이 나옵니다. 만일 nscd를 띄우지 않고 /etc/passwd등의 파일의 모드를 400로 한경우에는 UID만 나오게 됩니다.
2.29 NT와 Solaris의 비밀번호를 같이 관리하려면?
(이 부분은 제가 잘 몰라서 뉴스그룹에 올라온 몇가지 글들을 종합해 봅니다.) 우선 Solaris 2.6을 써야합니다. 그리고 Samba를 사용할 때 pam nt_dom이라는 모듈을 사용하시면 Solaris에서 NT의 비밀번호를 변경할 수 있습니다. 그리고 반대로 NT에서 Solaris의 비밀번호등을 관리하려면 Solstice Intranet Extension(Sun의 홈페이지를 보면 Solstice NFS Client 3.1라고 되어있습니다.) 프로그램을 NT에 설치하면 됩니다. 이 프로그램을 사용하면 Solaris가 NIS/NIS+를 사용하셔도 변경할 수 있습니다.
2.30 root 비밀번호를 잊었습니다.
CD-ROM으로 부팅하셔서 하드디스크의 /etc/shadow 파일의 비밀번호부분을 지우시면 됩니다. / 파티션이 /dev/dsk/c0t0d0s0인경우에 아래와 같은 작업을 하시면 됩니다.
ok boot cdrom -s
..
# mount /dev/dsk/c0t0d0s0 /mnt
# TERM=sun;export TERM
# vi /mnt/etc/shadow
# sync; reboot
2.31 /home에 파일을 쓰려면 어떻게 해야 하나요?
Solaris 2.x에서는 /home을 automounter가 mount해서 사용하기 때문에 root라 할지라도 디렉토리나 파일을 만들 수 없습니다. 하지만 실재로는 automounter를 쓰지 않는 경우에도 /home을 쓸 수 없다면 문제가 되겠죠? 이때 /home은 automount를 하지 않으려면 /etc/auto_master파일에서 /home부분을 주석처리 하면 됩니다.
2.32 계정을 만들 때 자동적으로 .cshrc와 .profile등의 파일을 만들려면?
/etc/skel 디렉토리에 복사하고 싶은 파일들을 만들어 두고 useradd나 admintool로 계정을 만들면 됩니다.
2.33 /etc/passwd파일에서 삭제를 했는데도 로긴이 가능합니다.
만일 NIS를 사용하시면 NIS에서 계정을 삭제하고, NIS map을 rebuild해줘야 합니다.자세한 내용은 NIS의 메뉴얼을 참조하세요.
2.34 passwd를 실행했는데 없는 ID라고 나옵니다.
/etc/shadow나 /etc/passwd의 정보가 잘못되었을때, 비밀번호를 변경하기 위해 passwd를 실행하면 아래와 같은 메세지가 나옵니다.
% passwd
passwd: Changing password for id
passwd(SYSTEM): id does not exist
권한이 거부됨
%
따라서 이 두개의 파일을 찬찬히 살펴보신 후 필요없는 라인이 추가되지 않았는지 아니면 계정에 들어갈 수 없는 글자가 있지는 않은지 확인해 보시기 바랍니다.
2.35 package란 뭔가요?
package는 원래 SVR4에서 프로그램의 설치와 삭제등을 쉽게하기 위해서 필요한 파일을 묶어둔 것을 말합니다. 하지만 주로 Solaris에서 프로그램의 배포에 사용되는 형식을 지칭합니다.
package를 구할 수 있는 가장 대표적인 곳으로 ftp://sunsite.unc.edu/pub/solaris와 http://sunfreeware.com이 있습니다. 전자에서는 몇가지 대표적인(gcc등) 패키지와 sunfreeware에서 배포하는 패키지를 미러링하고 있습니다. 국내에서는 대표적으로 ftp://ftp.kreonet.re.kr/pub/Sun/binaries와 ftp://sunsite.snu.ac.kr/pub/packages/sun_binary에서 미러링을 하고 있습니다. 이 곳에는 sparc와 i86pc 디렉토리가 있는데, 각각 sun의 sparc용 solaris와 solaris for x86용 package들이 있습니다. 그리고 freeware 디렉토리에는 후자에서 배포되는 package들이 있습니다.
package를 설치할 때는 pkgadd라는 명령을 사용하면 됩니다. 사용방법은 pkgadd -d 디렉토리명 pkg명입니다. 일반적으로 자주 설치하는 패키지인 ftp://sunsite.unc.edu/pub/solaris/sparc/GNUgcc.2.8.1.SPARC.Solaris.2.6.pkg.tgz의경우 다음과 같이 입력하면 설치됩니다.
% gzip -d GNUgcc.2.8.1.SPARC.Solaris.2.6.pkg.tgz
% tar -xf GNUgcc.2.8.1.SPARC.Solaris.2.6.pkg.tar
% pkgadd -d .
가져온 패키지들을 gzip와 tar로 풀면 각각 디렉토리가 만들어지고, 필요한 파일들이 그 디렉토리에 들어갑니다. 그리고 pkgadd명령을 실행하면 설치가능한 패키지들이 나열됩니다.(만일 디렉토리는 분명히 있지만 화면에 나열되지 않는다면 패키지의 디렉토리의 소유권이 적당한지 확인해 보시기 바랍니다.) 사용자가 원하는 번호를 입력하면 설치를 시작합니다.일반적인 패키지의 설치과정이 위와 같지만, 가끔 뉴스그룹으로 질문을 하시는 분들중에 http://sunfreeware.com에서 받아온 패키지의 경우에는 디렉토리가 만들어 지지 않고 pkgadd -d . 를 해도 화면에 나오지 않기때문에 질문하시는 분이 많습니다. 이때는 pkgadd -d 파일명 을 입력하시면 됩니다. 간단하게 예를들어 보죠.
% gzip -d bison-1.24.gz
% pkgadd -d bison-1.24
위와 같이 간단하게 입력하면 설치하실 수 있습니다.
참고로 http://sunfreeware.com에서 가져온 패키지들은 특별한 언급이 없는한 /opt에 설치됩니다. 그에비해 sunsite에서 가져온 패키지들은 일반적으로 /usr/local에 설치됩니다.
2.36 CDE는 뭔가요?
CDE(Common Desktop Environment) (아직 추가하지 못했습니다. 죄송합니다.)
CDE는 Solaris 2.6이라면 OS에 포함되어 있고, 그 이하 버전이면 OS와 같이 들어있는 CD-ROM에서 구할 수 있습니다. 만일 CD-ROM에 없거나, CD가 없을경우에는 ftp://sunsolve.sun.com/pub/cde/ 에서 받을 수 있습니다. 이 디렉토리에 가시면 파일이 여러가지가 있습니다. 파일이름중에 dev가 들어간 것은 developer를 의미하며 ab가 들어간 것은 answerbook이 포함되어있다는 의미입니다.
2.37 CDE로긴(dtlogin)의 설정은 어떻게 하나요?
다음과 같은 문제를 생각해 보죠.
처음 CDE를 설치할 때 영문으로 설치를 했습니다. 나중에 한글환경을 쓰려고 CDE에서 ko로 설정을 했는데 한번뿐이고 다시 로그아웃을 하면 영문으로 돌아갑니다. CDE의 기본언어를 설정하려면 어떻게 하면 되나요?
이경우 여러가지 방법이 있지만 다음의 방법을 이용해 보세요. 우선 /etc/dt/config디렉토리를 만듭니다. (만일 디렉토리가 있다면 만들지 마세요.) 그다음 /usr/dt/config/Xconfig를 만든 디렉토리로 복사합니다. (/usr/dt/config/Xconfig는 수정하시면 안됩니다.) 그리고 /etc/dt/config/Xconfig중에서 Dtlogin*language의 값을 ko로 바꾸시고 저장할 후에 dtconfig -reset을 실행하면 됩니다.
또한 CDE를 설치하면 기본적으로 dtlogin이 뜹니다. 이 화면대신에 원래 로긴화면을 사용하려면 dtconfig -d 와 같이 입력하시면 됩니다. 만일 CDE로긴화면이 뜨게 하려면 dtconfig -e 와 같이 입력하시면 됩니다.
2.38 부팅할 때 마다 어떤 일을 수행하려면 어떻게 하나요?
Solaris는 /etc/rcX.d(X는 S, 0, 1, 2, 3)에서 필요한 스크립트를 수행합니다. 만일 Single User모드로 부팅했다면 /etc/rcS.d에 있는 파일들을, 보통때는 모두다 수행합니다. 따라서 이들중 한 디렉토리에 SXXfilename(XX는 원하는 두자리 숫자, filename은 임의의 이름)이라는 파일을 만들고, shell script형태로 적어주면 됩니다. rc 프로세스는 숫자가 작은 스크립트부터 차례로 수행해 줍니다. (파일을 만들때는 단순히 명령어만 적어도 되지만, 다른 파일을 참조해서 만들기 바랍니다.)
그리고 SunOS 4.1.x에서는 /etc/rc.* 파일에 적어넣어면 됩니다. 일반적으로 rc.local에 적는 경우가 많습니다.
2.39 부팅시 마운트되는 순서는?
가장 먼저 /와 /usr는 읽기전용으로 마운트합니다. 이때 문제가 있다면 커널이 이 두개의 파티션에 대해 fsck를 수행합니다. 그리고 문제가 없다면 두번째로 swap을 마운트합니다. 세번째로 /와 /usr를 쓰기가 가능하도록 다시 마운트합니다. 그 이후에 /usr/platform, /proc, /dev/fd등을 차례대로 마운트합니다.
/etc/vfstab을 보면 / /usr /var 파일시스템은 mount at boot항목이 no로 되어있습니다. 따라서 이 파티션이 언제 마운트되는지 궁금해 하시는 분들이 많은데, / /usr /var는 부팅과정에 필요한 파티션이기 때문에 커널이 미리 마운트합니다. 그래서 /etc/vfstab에서는 no로 설정이 되어 있는것입니다.
2.40 다른 시스템의 X Window 프로그램을 수행하고 싶습니다.
디스플레이를 사용하는 시스템에서 xhost로 프로그램이 있는 시스템을 적어주고, 프로그램이 있는 시스템의 DISPLAY환경변수를 수정하면 됩니다. 만일 A가 현재 사용하는 컴퓨터(X Server)이고 B가 응용프로그램이 있는 컴퓨터라면 아래와 같이 입력하면 됩니다. (csh를 사용한다고 가정)
[A]% xhost + B
[A]% telnet B
[B]% setenv DISPLAY A:0.0
[B]% 응용프로그램
2.41 로컬시스템의 X 프로그램을 실행했는데 display를 열수없다고 합니다.
같은 시스템이더라도 telnet이나 su로 한번 거쳐서 접속한 경우에는 아래와 같은 에러가 발생합니다.
Error: Can't open display: unix:0
이때는 su나 telnet전에 xhost + localhost등을 입력해 주고, su나 telnet후 DISPLAY환경변수를 localhost:0.0으로 설정하시면 됩니다.
2.42 libX11.so.6.1이 없다고 에러가 납니다.
Solaris 2.6이라면 openwindow가 X11R6를 지원합니다. 따라서 /usr/openwin/lib/libX11.so.4 를 가리키는 libX11.so.6.1을 만들면 됩니다.
Solaris 2.5.1 이하라면 시스템의 버젼에 맞는 X11R6 패키지를 설치하시면 됩니다.
혹 LD_LIBRARY_PATH가 적절히 설정되지 않은경우도 있습니다. 이 환경변수도 확인해 보시기 바랍니다. 참고로 LD_LIBRARY_PATH는 동적라이브러리(libX11.so.6등의 라이브러리)가 있는 디렉토리들을 지정하고 있습니다. 만일 /usr/local/X11R6/lib를 추가하고 싶다면 아래와 같이 입력하면 됩니다.(csh이라고 가정)
setenv LD_LIBRARY_PATH $LD_LIBRARY_PATH:/usr/local/X11R6/lib
2.43 최근 login한 사람들에 대한 정보를 알수 없나요?
사용자들이 login하면 그 정보가 /var/adm/utmp에 저장됩니다. 이 파일에 저장된 내용을 출력해주는 프로그램이 /usr/bin/last입니다. 그리고 참고적으로 /var/adm에는 utmp, utmpx, wtmp, wtmpx가 있는데 utmp, wtmp는 같은 파일이고 utmpx, wtmpx는 utmp의 확장파일입니다. 만일 어떤 사용자의 최근 접속상황을 보려면 last id라고 하시면 됩니다.
utmp, wtmp, lastlog등은 사용자가 시스템에 접속했을 때 로그가 기록되는 파일로 /usr/bin/login프로그램에 의해 만들어집니다. 만일 만들고 싶지 않다면 login프로그램을 수정(?)하시든지, 아니면 주기적으로 지워주는 방법밖에 없습니다. 주기적으로 지워줄때는 cron등을 이용하시면 편리합니다. 그리고 아예 만들지 않으려면 wtmpx등의 파일을 /dev/null의 링크파일로 만드는 방법이 있습니다.
2.44 syslogd는 어떤 역활을 하나요?
언제, 어디서, 누가, 어떤 서비스를 통해서 시스템에 접속을 시도했는지를 기록해주는 서버입니다. 대표적으로 telnet, ftp, mail등에 대한 로그를 만들어줍니다. 그리고 syslogd에 대한 설정파일은 /etc/syslog.conf입니다. syslogd에 의해 만들어진 log파일은 /var/log에 생성됩니다.
/etc/hosts에 보면 loghost라는 부분이 있습니다. 이 부분은 syslogd에 의해 사용됩니다. (추가설명 필요)
2.45 cron이 실행되지 않습니다.
crontab에 등록하려고 하니 다음과 같은 메세지가 나옵니다. 이런경우에는
cron may not be running - call your system administrator
warning: commands will be executed using /usr/bin/sh
cron을 사용하려면 cron.allow에 등록이 되어있어야 합니다. 첫번째 메세지는 cron.allow에 등록이 되어있지 않기 때문에 생기는 메시지입니다. 그리고 cron은 /bin/sh를 기본쉘로 사용하지만 /bin이 /usr/bin에 링크되어있기 때문에 두번째와 같은 에러가 출력됩니다. 따라서 두번째 메시지는 무시하셔도 됩니다.
2.46 Solaris 2.x에서 시스템의 최대값을 알려면?
Solaris 2.x에서 시스템의 maximum값(maximum filesize, maximum stacksize 등등)은 ulimit를 사용하면 알 수 있습니다. 이 값을 바꾸려면 /etc/system파일에 합니다. 다음은 사용자당 사용할 수 있는 최대 프로세스갯수와 시스템의 최대 프로세스갯수를 설정하는 예제입니다.
set maxuprc=512
set max_nprocs=1024
시스템의 메시지큐 크기를 변형하려면/etc/system 에 msginfo_msgmnb xxx 와 같이 (xxx는 큐의 크기) 적으면 됩니다.
2.47 Solaris에서 hostid를 변경하려면?
host ID는 변경할 수 없습니다.(원칙) 하지만 가끔 변경하는 프로그램이 나오곤 하죠.(Solaris 2.5의 hid2, SunOS 4.1.3의 sethostid 등) hid2는 ftp://ftp.mindlink.net/pub/crypto/sun-stuff/change-sun-hostid.tar.gz에서 구할 수 있습니다.
2.48 Solaris 2.x는 y2k에 안전한가요?
http://www.sun.com/y2000에 가시면 Sun제품의 y2k 에 관한 내용을 알 수 있습니다. 일반적으로 Recommended Patch를 설치하고, y2k Patch를 설치하시면 됩니다.
2.49 TT_DB/ 디렉토리는 뭔가요?
Solaris의 서비스중에 rpc.ttdbservd가 TT_DB 디렉토리에 데이터베이스를 생성, 삭제합니다. 따라서 rpc.ttdbservd를 띄우지 않는다면, 삭제하셔도 됩니다. (박창민님)
2.50 Solaris 2.6에서 2GB이상의 파일을 사용하려면?
Solaris 2.6에서 프로그램이 2GB이상의 파일을 지원하려면 2.6에서 아래의 옵션을 사용하여 컴파일해야 합니다. (이석찬님)
CFLAGS = "`getconf LFS_CFLAGS`"
DEFS = -D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64
LDFLAGS = "`getconf LFS_LDFLAGS` -s"
LIBS = "`getconf LFS_LIBS`"
따라서 Solaris 2.6이 아닌 시스템에서 컴파일된 프로그램은 위의 옵션을 사용하여 다시 컴파일 하셔야 합니다.
2.51 talk에서 한글을 쓰려면?
LANG환경변수를 ko로 설정하고, /usr/SUNWale/bin/talk를 사용하면 됩니다.
2.52 비밀번호 없는 계정을 만들려면?
SunOS 4.x까지는 /etc/passwd에 비밀번호란을 지우면 되지만, Solaris 2.x에는 비밀번호를 관리하는 /etc/shadow의 비밀번호란을 지워도 로긴하면 다시 입력하게 되어있습니다. 이때 로긴시 비밀번호를 입력하지 않도록 하려면 /etc/default/login에서 PASSREQ=NO로 만들면 됩니다.