| ||
Всем известно мнение, что установить Oracle версий 8.1.x на FreeBSD легче всего установкой на Linux, и дальнейшим копированием уже установленных файлов. Это объясняется тем, что трудностей от изучения Linux'а значительно меньше, чем трудностей от установки Oracle на FreeBSD.
Но поскольку, мы пионеры, легких путей не ищем, то в этой статье я поделюсь собственным двухнедельным опытом честной установки Oracle 8.1.7 на FreeBSD 4.2
Об установке Oracle 8.0.x на FreeBSD уже рассказывается даже в HandBook'e. Главным отличием установки Oracle 8.1.x от 8.0.x является инсталлятор на Jave. Этот язык (скорее даже концепция) программирования до сих вызывает много споров. Действительно: если бы не инсталлятор на Java, установка Oracle на FreeBSD проходила бы более безболезненно.
Ознакомившись с содержанием конференций, единственным материалом, который я нашел оказалась статья на японском: http://www.tokuda.net/FreeBSD/oracle816.html Зарядившись оптимизмом, и вооружившись переводчиком с AltaVist'ы, изучил ее и принялся следовать данным в ней указаниям. Однако, столкнулся с рядом проблем, затянувшими процесс установки на две недели. Если честно, то я уже почти отчаялся когда-либо завершить процесс установки, пока, наконец, случаяно не нашел решение одной из стоявших проблем. Чтобы с вами подобного не было, я поделюсь собственным опытом борьбы с Oracle и его инсталлятором.
Ну довольно лирики, теперь о конфигурации системы:
- Сервер IBM, Pentium-III, 256+128Mb ОЗУ.
- Операционная система FreeBSD-4.2 Release, самая стандартная,
cvs-ом не обновлялась.
- Дистрибутив Oracle: linux81701.tar - 549.867.520 байт
Для этого из-под root'а устанавливаем два пакаджа: linux_base и linux_devtools
matrix# pkg_add linux_base-6.1.tgz matrix# pkg_add linux_devtools-6.1.tgz
matrix# kldload linux
(не спешите прописывать linux_enable="YES" в /etc/rc.conf, его скорее всего, оттуда придется убрать..)
Когда запускается программа, являющаяся бинарным файлом linux'а, во-первых, линуксолятор обеспечивает поддержку системных вызовов linux'а, а во-вторых, когда программа обращается к какму-либо файлу, например /etc/passwd, линуксолятор сначала подставляет в начало строчки путь окружения linux'а: /compat/linux/etc/passwd, и проверяет наличие такого объекта файловой системы. Если он есть - программа использует именно этот объект, если его нет - путь к файлу остается без изменений: /etc/passwd.
За счет того, что форматы основных файлов конфигурации между FreeBSD и Linux одинаковы, окружение linux не дублирует в себе настройки системы, и linux-приложения прекрасно используют файлы вроде /etc/passwd из конфигурации FreeBSD.
Однако инсталлятор Oracle использует информацию о разделах файловой системы, которую ищет в /etc/mtab. Изначально такого файла нет, поэтому его нужно создать:
matrix# cp /etc/fstab /compat/linux/etc/mtab
Как вы уже догадались, когда linux-приложение запросит файл /etc/mtab, "линуксолятор" сначала подставит путь /compat/linux/etc/mtab, где и найдет требуемый файл. Очень удобно, ведь не приходится замусоривать собственный /etc файлами, необходимыми только linux-приложениям.
Общераспостраненно их в Unix'ах три: /tmp, /usr/tmp, /var/tmp. Но поскольку мало кто выделяет много места под файловые системы / и /var, то частенько какие-то из этих объектов файловых систем являются не отдельными каталогами, а всего лишь символьными ссылками.
Когда я первый раз пытался производить установку, во время инициализации набора компонентов, подлежащих установке, происходил сбой: "Problem opening staging area", и вылетало совершенно нелепое предложение проверить еще раз правильность указания исходного каталога.
Ни в руководстве на tokuda.net, ни в Usenet-конференциях, я не смог найти описания подобной проблемы. Однако, нечаянно я заметил что если не закрывать окошко с сообщением об ошибке, то в /tmp/OraInstall остается файлик с именем temp0. Последовав доброму совету использовать ktrace для выяснения причин подземных стуков, я обнаружил весьма забавную картину:
matrix# kdump | grep temp --------------------------------------------------- 47007 jre NAMI "/compat/linux/tmp/OraInstall/temp0" 47007 jre NAMI "/tmp/OraInstall/temp0" 47007 jre NAMI "/tmp/OraInstall/temp0" 47007 jre NAMI "/compat/linux/var/tmp/OraInstall/temp0" 47007 jre NAMI "/var/tmp/OraInstall/temp0"
Выходит, инсталлятор создавал этот файлик в /tmp/OraInstall, а искал в /var/tmp/OraInstall?
Поэтому, прежде чем начинать установку, давайте разберемся с местами временного хранения файлов. А чтобы линуксолятор не смог напутать программам пути, проверяем, чтобы таких объектов файловой системы, как /compat/linux/tmp, /compat/linux/usr/tmp, /compat/linux/var/tmp вообще не было. То есть не было с такими именами ни директорий, ни символьных ссылок на другие директории.
matrix# rm /compat/linux/tmp matrix# rm /compat/linux/usr/tmp matrix# rm /compat/linux/var/tmp
По умолчанию паккадж linux_base-6.1 создает /compat/linux/usr/tmp, который делает символьной ссылкой на /var/tmp. Мне кажется, это совершенно излишне. Когда всех трех выше перечисленных объектов файловой системы в /compat/linux/... существовать не будет, любая попытка линуксолятора подставить в путь /compat/linux закончится неудачей, в результате чего будут использоваться оригинальные каталоги /tmp, /var/tmp и /usr/tmp вашей системы.
Но это не все. Теперь нам нужно, чтобы /tmp, /var/tmp и /usr/tmp представляли один и тот же каталог. Определитесь, на какой файловой системе у вас больше всего места: на /, на /var или на /usr? У меня на /usr. Тогда /usr/tmp оставляем реальным каталогом, а /tmp и /var/tmp - символьными ссылками на него. Если содержимое tmp-ов не жалко, это может выглядить так:
matrix# rm -r /var/tmp/* matrix# ln -s /usr/tmp /var/tmp matrix# rm -r /tmp/* matrix# ln -s /usr/tmp /tmp
После этого процесса могут пострадать запущенные программы, наподобие mysqld, которые могут держать в /var/tmp свои файлы-сокеты. Так что если полная работоспособность системы критична, то можно перегрузить сервер, не додидаясь пересборки ядра.. (а она еще предстоит).
Она необходима для того, чтобы инсталлятор Oracle вообще запуститься и функционировать как программа. Вообще говоря, установочный комплект Oracle содержит в себе родную JRE, однако она обладает паталогической несовместимостью с FreeBSD (да и с некоторыми Linux'ами, как оказалось).
Поэтому мы установим Blackdown JRE 1.1.8: jre118_v3-glibc-2.1.3.tar.bz2 - 7.156.122 байт
доступен этот продукт с www.blackdown.org или файловым поиском через www.filesearch.ru
Поскольку запакован этот архив bzip2, то для распаковки необходимо установить этот архиватор (если он у вас до сих пор не установлен):
matrix# pkg_add bzip2-1.0.1.tgz
затем распаковываем архив с JRE:
matrix# cd /compat/linux/usr matrix# tar --bzip2 -xvf /tmp/jre118_v3-glibc-2.1.3.tar.bz2
В каталоге /compat/linux/usr должен появиться подкаталог jre118_v3. Создадим внутри него каталог linux, который будет являться символьной ссылкой на /compat/linux/usr/jre118_v3.
matrix# cd /compat/linux/usr/jre118_v3 matrix# ln -s . linux
Это пригодится когда мы будем пытаться подменить родную Oracl'ову JRE Blackdown'овской.
Утилита arch используется в linux для вывода информации об архитектуре машины. Ни в окружении /compat/linux/..., ни во FreeBSD подобной утилиты нет. Поэтому создаем ее сами, благо это дело не хитрое:
matrix# echo echo i686 > /compat/linux/bin/arch matrix# chmod +x /compat/linux/bin/arch
Blackdown JDK 1.2.2 адаптированная для FreeBSD есть в портах: /usr/ports/java/linux-jdk.
Однако я использовал обновленную версию этого порта. Для этого с ftp вытаскиваем весь каталог (вместе с подкаталогами): ftp://ftp.freebsd.org/pub/FreeBSD/ports/ports-stable/java/linux-jdk и кладем его в /usr/ports/java/linux-jdk вместо оригинального. Решать, будете ли вы использовать обновленную версию порта, или ограничитесь имеющейся в вашей системе - решать вам. Могу только предостеречь, что вообще-то требуется Blackdown JDK 1.1.8, но то, что есть в linux-jdk (Blackdown JDK 1.2.2) вроде проблем не вызвало. Остальные порты, вроде linux-jdk13, linux-jdk14, linux-sun-jdk12, linux-blackdown-jdk13, linux-ibm-jdk13 сюда явно не подходят.
Итак, автоматически достаем порт из Интернет, компилируем и устанавливаем:
matrix# cd /usr/ports/java/linux-jdk matrix# make install
Если все прошло успешно, порт будет установлен в /usr/local/linux-jdk1.2.2 Но это еще не все, на него нужно создать символьную ссылку:
matrix# ln -s /usr/local/linux-jdk1.2.2 /compat/linux/usr/local/java
Пусть это будут oracle:dba. На всякий случай я еще создал группу oinstall, и добавил в нее пользователя oracle.
Таким образом, в файл /etc/group у меня добавились две строчки:
dba:*:94: oinstall:*:95:oracle
целочисленные идентификаторы групп GID у вас могут быть другими.
Теперь создаем пользователя oracle - с помощью команды vipw добавляем в файл пользователей следующую строчку:
oracle:*:94:94::0:0:Oracle Server:/usr/oracle:/compat/linux/bin/bash
первая цифра 94 означает UID пользователя oracle и может быть любой, вторая - это GID группы dba.
Устанавливаем для пользователя oracle пароль (в процессе установки нам будет приходиться login'иться под ним с консоли):
matrix# passwd oracle
matrix# mkdir /usr/oracle
Создаем профиль пользователя oracle и устанавливаем в нем все необходимые переменные окружения:
matrix# vim /usr/oracle/.profile ORACLE_BASE=/usr/oracle; export ORACLE_BASE ORACLE_HOME=/usr/oracle; export ORACLE_HOME LD_LIBRARY_PATH=$ORACLE_HOME/lib; export LD_LIBRARY_PATH ORACLE_SID=ORCL; export ORACLE_SID PATH=/compat/linux/bin:/compat/linux/sbin:/compat/linux/usr/bin:/compat/linux/usr/sbin:/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:$ORACLE_HOME/bin export PATH
Передаем домашний каталог со всем его содержимым в распоряжение пользователю и группе:
matrix# chown -R oracle:dba /usr/oracle
matrix# mkdir /usr/orainstall matrix# cd /usr/orainstall matrix# tar -xfv /tmp/linux81701.tar
Распаковка дистрибутива oracle - достаточно длительный процесс. И пусть вас не смущает, что это действие производится, как и все предыдущие, из-под root'а - пользователю oracle совершенно не нужно иметь права собственности на свой установочный комплект.
После распаковки оказалось, что дистрибутив представляет собой каталог Disk1, внутри которого уже находятся каталоги doc, install locks, patch, response и stage. Скорее всего, расположение каталогов может быть и другим, в зависимости от версии дистрибутива, но смысл всех действий скорее всего будет тем же самым.
Созданный каталог /usr/orainstall вместе с распакованным дистрибутивом после установки Oracle можно будет удалить.
Сначала редактируем файл runInstaller:
matrix# cd /usr/orainstall/Disk1 matrix# cp runInstaller runInstaller.org matrix# vim runInstaller
ищем строчку, содержащую THREADS_FLAG=native и заменяем ее на THREADS_FLAG=green
Теперь правим oraparam.ini
matrix# cd /usr/orainstall/Disk1/install matrix# cp oraparam.ini oraparam.org matrix# vim oraparam.ini
ищем строчку JRE_LOCATION=../stage/Components/oracle.swd.jre/1.1.8/1/DataFiles/Expanded/linux
и заменяем ее на JRE_LOCATION=/compat/linux/usr/jre118_v3/linux
(обратите внимание на взаимное соответствие окончаний обоих строчек:
...Expanded/linux -> /compat/linux/usr/jre118_v3/linux).
В статье на tokuda.net говорится, что установка Oracle не требует изменение параметров ядра, и в них нуждается только сам Oracle. К сожалению, это от части не верно.
Пока я не догадался, какие опции надо вкомпилировать в ядро, установка Oracle у меня постоянно вылетала по 11 сигналу, с сообщением segmentation violation. Причем это происходило именно тогда, когда указатель процесса копирования файлов достигал значения 35%
Запущенный при этом top показывал прямо-таки дикое пожирание памяти установщиком, а вываливание примерно тогда, когда объем отъеденной памяти превышал 750Mb - хотя, если верить top'у, swap был использован всего на 55%
Использование ktrace ясности не внесло, правда получалось так, что в течении всего этого времени установщик Oracle честно копировал разные файлы, и никаких признаков зацикливания не обнаруживал. Более того, сравнение нескольких неудачных попыток установки показало, что она даже вылетала на копировании разных файлов: те файлы, которые оказались для установщика последними во второй попытке, в первой были успешно преодолены, и выброс по SIGSEG #11 произходил чуть позже.
К своим 256+128Mb ОЗУ и 512Mb swap я добавил еще 1000Mb swap-file, но ситуация не изменилась: установщик Oracle по-прежднему вываливался на 750Mb памяти, разве что swap теперь был заполнен не на 55% а на 18%
Ни шаманство, ни танцы с бубном не давали результата, пока в качестве уже которой по счету "последней попытки" не были внесены изменения в ядро, оказавшиеся критическими:
Во-первых, я увеличил maxusers с 32 до 64 - однако, если верить param.c на нашу ошибку это влиять не должно.
Во-вторых, я добавил строчку options MAXMEM="(1024*1024)" - это тоже вроде ничего не дает, так как BIOS не врал, и top объем оперативной памяти всегда показывал правильно.
И наконец, третье изменение, которое, по моему мнению, и является ключом к разгадке причины возникновения signal 11 и segmentation violation. Я добавил:
options MAXDSIZ="(1024*1024*1024)" options DFLDSIZ="(1024*1024*1024)"
В описании этих параметров в ядре LINT говорится следующее: "Некоторые приложения могут выходить за 128Mb предел, который во FreeBSD изначально заложен. Используйте эти параметры, чтобы увеличить этот предел. MAXDSIZ - это максимальное значение, которое может принимать этот предел, DFLTDSIZ - его значение по умалчанию. Задав значение DFLTDSIZ меньше MAXDSIZ, вы после сможите для некоторых процессов поднять значение этого предела до MAXDSIZ, с помощью переменных Shell
Не совсем понятно, про какой предел идет речь. Самое интересное, что в этом абзаце ни слова не сказано про "память" или "memory". Такое ощущение, что эта опция относится не к объему памяти, а к чему-то иному. По умолчанию пределом этого чего-то является 128Mb, в ядре LINT продемонстрированно, как сделать этот предел равным 256Mb, я же с русским размахом установил его равным 1024Mb. Ничего, работает..
Итак, давайте внесем изменения в конфигурацию вашего ядра. У меня это выглядит так:
matrix# cd /sys/i386/conf matrix# vim ./MATRIX
В ядро добавим следующие строки:
options SYSVSHM #SystemV-style shared memory options SYSVMSG #SystemV-style message queues options SYSVSEM #SystemV-style semaphores
(по умолчанию эти три строчки включены в ядро GENERIC FreeBSD-4.2Release)
options SHMMAXPGS=10000 options SHMMNI=100 options SHMSEG=10 options SEMMNS=200 options SEMMNI=70 options SEMMSL=61
(это параметры поддержки SystemV)
pseudo-device vn 1
(это нужно для создания swap-файла)
После всех этих добавлений компилируете и устанавливаете новое ядро.
matrix# cd /sys/i386/conf matrix# config MATRIX matrix# cd ../../compile/MATRIX matrix# make depend matrix# make matrix# make install
Но сервер не перегружаем!
Вообще, использовать его или нет, решать вам. Если суммарный объем ОЗУ и swap'а на Вашем сервере составляет около 1 Gb, то, вероятно, можно обойтись без swap-файла. В противном случае я бы посоветовал увеличить swap за счет создания дополнительной swap-партиции или swap-файла. К сожалению, неразмеченного места на диске под swap-партицию у меня не оказалось, поэтому расскажу как создать swap-файл.
Сначала создаем одно vn (virtual-node) устройство:
matrix# cd /dev matrix# sh ./MAKEDEV vn0
Теперь создаем сам файл подкачки размером 1 Gb:
matrix# dd if=/dev/zero of=/usr/swap0 bs=1024k count=1024
Устанавливаем права на него:
matrix# chmod 600 /usr/swap0
Подключаем созданный файл подкачки. Для этого в /etc/rc.conf дописываем строчку:
swapfile="/usr/swap0"
После чего наконец-то перегружаем сервер:
matrix# reboot
тем самым убеждаясь, что наш swap-файл успешно подключен к системе. Теперь вроде все готово к установке..
Снова загружаем поддержку linux'а:
matrix# kldload linux
Login'имся с обчыной текстовой консоли пользователем Oracle. Пользователь должен без проблем зайти в систему, sell'ом у него будет linux'овый bash, а приглашение командной строки будет иметь вид:
[oracle@matrix oracle]$
Убедитесь, что все опеременные окружения, которые мы описали в .profile выстанавлены:
[oracle@matrix oracle]$ set | more
После чего выходим из-под пользователя oracle.
Если для установки 8.0.5 он был нужен чтобы в xterm запустить текстовый установщик, который плохо понимал termcap, и напрочь отказывался обеспечивать перемещение по своим красивым менюшкам, то теперь весь установщик написан под GUI.
К слову сказать, никаких KDE и прочих оконных менеджеров не понадобится. Голые X-ы, со стандартным VGA прайвером 640x480 и 16 цветов вполне подойдут. И хотя окно установщика будет размером строго на весь экран, вылазанья за него отдельных частей окна замечено не было.
matrix# xdm
Первым окном, которое появится, будет окно xterm'а с приглашением вида:
bash$
Это тот же линуксовый bash, однако в xterm'е он запущен не в роли login shell'а, поэтому он даже не удосужился прочитать из .profile переменные окружения, что, впрочем, легко проверить:
bash$ set | more
Установленных перменных ORACLE_BASE и ORACLE_HOME мы здесь не увидим. Для того, чтобы bash считал из .profile значения этих переменных, его необходимо запустить в роли login shell'а. Для этого прямо в xterm'e набираем:
bash$ bash -login
Приглашение сразу принимает привычный вид [oracle@matrix oracle]$, а выполнив команду:
[oracle@matrix oracle]$ set | more
убеждаемся в том, что значения всех переменных из .profile выставлены корректно.
Теперь отключаем локализацию языка. Установщик Oracle распознает текущее значение переменной языка, и в зависимости от этого использует различные строки для своего интерфейса. С одной стороны это хорошо, потому как видеть сообщения о процессе установки на русском языке приятно, с другой стороны в usenet неоднократно пробекали статьи, что установщик невсегда корректно справляется с подобной языковой подстановкой. Поэтому, чтобы быть уверенным, что ошибки установки никак не связаны с нашей национальной принадлежностью, снимем значение переменной окружения LANG:
[oracle@matrix oracle]$ unset LANG
Все в том же xterm'е, от имени пользователя oracle, наберите:
[oracle@matrix oracle]$ cd /usr/orainstall/Disk1 [oracle@matrix oracle]$ ./runInstaller
И если судьба сжалится над вами, и случится чудо, то вы увидите сначала сообщение "Inintializind Java Virtual Machine from /compat/linux/usr/jre118_v3/bin/jre. Please wait..", а затем и плавно возникающую эмблему Oracle Installer, прожорливого монстра, написанного на языке Java.
Если эмблемки не появилось, а runInstaller вывалился с сообщением об ошибке, посторайтесь проанализировать это сообщение. Скорее всего это связано с инициализицией JRE. Проверьте верно ли была произведена коррекция файлов runInstaller и oraparam.ini, привильно ли распакована JRE. Вообще говоря, наша версия JRE использует glibc 2.1.3, а паккадж linux_base-6.1 от FreeBSD 4.2Release содержит glibc 2.1.2, однако я еще ни разу не слышал, чтобы с этим возникали проблемы. По крайней мере у меня Java-установщик заработал с первой попытки, и в этом отношении проблем удалось избежать.
Поэтому, если runInstaller у вас не запустился, проверьте пути к JRE, права на /usr/oracle и временные каталоги, постарайтесь разобрабраться в причинах ошибки. Все же, надеюсь, такой проблемы не возникнет.
Первый экран (Welcome) пропускаем.
На втором экране нам предлагают выбрать source и destination locations. Если все переменные окружения назначены правильно - в этих полях уже будут стоять соответствующие директории. Нажимаем Next.
Теперь Oracle инсталлер будет некоторое время загружать "Product information", после чего спросит UNIX Group Name - группу пользователей которые будут иметь права на добавление компонентов Oracle. Поскольку ничего добавлять я не собираюсь (да и не знаю, что еще из монстроидальных продуктов Oracle можно портировать на FreeBSD), то я выбрал группу dba. Вероятно, с таким же успехом можно было использовать группу oinstall.
Теперь системе потребуется сохранить информацию об Oracle Inventory - месте, где будет храниться информация об установленных продуктах Oracle и о той группе, которая имеет право изменять эту информацию. Для этого ей нужны администраторские привелегии: она попросит запустить из-под root'а файл /usr/oracle/orainstRoot.sh. Переключитесь на текстовую консоль, зайдите root'ом и запустите этот файл:
matrix# cd /usr/oracle matrix# ./orainstRoot.sh
Это приведет к созданию файла /etc/oraInst.loc, содержащего всю необходимую информацию. Сама же Inventory-база будет находится в /usr/oracle/oraInventory. Заметьте, если переменные окружения (в частности, ORACLE_HOME) были бы не выставлены, Oracle Installer еще после первого бы шага спросил бы о том, где эту Inventory directory располагать.
После вызова orainstRoot.sh вернитесь в X'ы, и нажмите Retry.
Установщик спросит у вас, какой именно продукт вы хотите установить. Нужно выбрать Oracle 8i Enterprise Edition 8.1.7 (Oracle Management&Integration и Oracle Client нам не нужны), и нажать Next.
Теперь вопрос каснется типа установки. Выбираем Typical (Minimal и Custom нам не подходят). Жмем Next.
После чего установщик начнет собирать сведения об устанавливаемых компонентах: в правом верхнем углу окна появится индикатор, который начнет постепенно заполняться.
Кстати, я заметил одну особенность: если X-приложение (по крайней мере Oracle Installer) чем-то очень сильно занято, а вам показывает безинтересный индикатор процесса, то все же не стоит переключаться в консоль для выполнения какх-то действий. Пару раз у меня вылетали X'ы во время таких переключений. Не знаю, чья это вина: X'ов, Oracle Installer'а или JRE, но по опыту могу сказать, что делать так не стоит.
Оставьте на мониторе царствовать XWindow и Oracle Installer'а, а сами подключитесь telnet'ом с другой машины, чтобы следить за состоянием системы с помощью top'а.
Следующим шагом (видимо в рамках процесса сборки сведений об устанавливаемых компонентах) оказался вопрос о Database Administrator Group и Database Operator Group. Я обе назвал dba, однако если есть желание разделить их привелегии, то создайте еще одну группу, не забудьте только включить в нее пользователя oracle.
Следующим шагом система просит определить путь к JDK 1.1.8 По умолчанию он определен как /usr/local/java Помните, мы создавали символьную ссылку:
/compat/linux/usr/local/java -> /usr/local/linux-jdk1.2.2
А помните, как работает линуксолятор? Правильно, когда Oracle Installer запрост путь /usr/local/java, линуксолятор сначала подставит /compat/linux/usr/local/java. А так объект файловой системы существует, и является символьной ссылкой на наш /usr/local/linux-jdk1.2.2
Не верите, что получится? Нажмите кнопку Browse.. Перед вами GUI'шное дерево, из которого наглядно видно, что по мнению Oracle Installer'а папка /usr/local/java содержит подпапки bin, demo, include, include-old, jre, lib. Убедились?!
Тогда путь к JDK оставляем /usr/local/java, и нажимаем Next..
Global Database Name я ввел такое же как и SID: ORCL
После чего список вопросов у установщика иссяк, и он наконец-то предложил перейти к действию: нажать кнопку Install. Мы ее тоже сейчас нажмем, но перед этим я добавлю, что по показанию top'а (запущенного, кстати, в telnet-сеансе с другой машины), jre сейчас даже в пассивном состоянии (отрисовав окошко и ожидая действий пользователя) использует около 19% ресурсов моего Pentium-III, и занимает уже 311Mb памяти! Сторонники Java, срочно посыпайте голову пеплом..
Ну что ж, с Богом: нажимаем кнопку Install..
А мы тем временем смотрим на показания top'а, и удивляемся, куда же этому jre столько памяти надо.. Около 35% индикатор на продолжительное время застревает, а затем достаточно быстро проходит остальные стадии. Что делается на этих 35% ответить затрудняюсь, могу сказать только, что после их прохождения объем памяти, который отъедает jre возрос с ~450 до ~850 Mb, а к концу установки составил ~1005 Mb.
Кстати, те, кто устанавливал Oracle на Linux поделились, что всего при установке, jre расходует около 640Mb памяти, что все-таки меньше чем 1Gb на FreeBSD. Зачем jre нужно 1 Gb памяти, и что она с ним делает, я бы сам с удовольствием узнал. Может она дистрибутив туда записывает?.. ;)
Итак, если процесс копирования файлов и пожирания памяти пройдет успешно, то в конце установки вы увидите уже знакомое сообщение, что установщику нехватает прав, чтобы запустить файлик /usr/oracle/root.sh, зайдите, мол, с консоли из-под root'а, и запустите его сами.
Однако, прежде чем мы сделаем это, давайте посмотрим, что же там внутри у этого файла, и внесем необходимые исправления:
В самом начале файла, и через еще две странички в его середине, прописываются пути к служебным программам Unix. Вот именно эти пути нам нужно и исправить. Вообще-то лучше проверить все эти пути самостоятельно, так как от версии к версии Oracle они добавляются.. я, например, сделал следующие исправления:
В начале файла:
CHOWN=/usr/sbin/chown TEST=/bin/test
В середине файла:
AWK=/usr/bin/awk CHOWN=/usr/sbin/chown GREP=/usr/bin/grep SED=/usr/bin/sed TEST=/bin/test
после чего, запускаем файл:
matrix# cd /usr/oracle matrix# ./root.sh
После запуска скрипт спросит путь к каталогу local bin:
Enter the full pathname of the local bin directory: [/usr/local/bin]:
с предложенным /usr/local/bin нужно согласиться и молчаливо нажать Enter.
вернитесь к установке и продлжите ее. Следующим этапом будет автоматический запуск Configuration tools, в процессе которого некоторые утилиты успешно отработают (вы увидите напротив них галочки), а на запуске некоторых (а именно Oracle database Configuration Assistandt) система обломается. После чего на экран будет выведено сообщение:
One or more tools have failed. It is recommended...
Ничего страшного. Базу данных мы создадим вручную. Нажимаем OK в диалоге об ошибке, говорим Next, и затем, приняв поздравления об окончании установки, Exit.
Заходим с текстовой консоли пользователем oracle:
[oracle@matrix oracle]$ cd /usr/oracle [oracle@matrix oracle]$ mkdir orcl [oracle@matrix oracle]$ cd orcl [oracle@matrix oracle]$ mkdir ddl data pfile archive bdump cdump udump
Затем берем этот файл: http://pm.stu.lipetsk.ru/~oracle/orcl.tgz и распаковываем его:
[oracle@matrix oracle]$ cd /usr/oracle/orcl [oracle@matrix oracle]$ tar zxfv /tmp/orcl.tgz
после чего запускаем:
[oracle@matrix oracle]$ cd /usr/oracle/orcl/ddl [oracle@matrix oracle]$ sh ./01crdb.sh
если все правильно, то поднимится экземпляр Oracle и начнется не быстрый процесс создания Базы данных, вместе со всеми сегментами, словарями и табличными пространствами...
[oracle@matrix oracle]$ sh ./02crdb.sh [oracle@matrix oracle]$ sh ./03crdb.sh [oracle@matrix oracle]$ sh ./05crtblsp.sh [oracle@matrix oracle]$ sh ./06cruser.sh
Естественно, желающие могут поковыряться в файлах и "заточить" их под себя. Я взял их с tokuda.net и подкорректировал пути. В результате выполнения последнего файла (06cruser.sh) будет создан пользователь demo с паролем demo, которому будут предоставлены все привелегии работы с базой данных.
Для пробы можно создать таблицу:
[oracle@matrix oracle]$ sqlplus SQL*Plus: Release 8.1.7.0.0 - Production on Mon Jun 3 10:59:53 2002 (c) Copyright 2000 Oracle Corporation. All rights reserved. Enter user-name: demo Enter password: demo Connected to: Oracle 8i Enterprise Edition Release 8.1.7.0.1 - Production With the Partitioning option JServer Release 8.1.7.0.1 SQL> @07cr_tbl.sql DROP TABLE T_GIJI CASCADE CONSTRAINTS * ERROR at line 1: ORA-00942: table or view does not exist Table created. Table altered. SQL> exit
[oracle@matrix oracle]$ svrmgrl Oracle Server Manager Release 8.1.7.0.1 - Production (c) Copyright 1997, 1999, Oracle Corporation. All Rights Reserved. Oracle 8i Enterprise Edition Release 8.1.7.0.1 - Production With the Partitioning option JServer Release 8.1.7.0.1 SVRMGR> connect internal Connected. SVRMGR> shutdown normal Database closed. Database dismounted. ORACLE instance shut down. SWRMGR> quit Server Manager complete.
[oracle@matrix oracle]$ vim /usr/oracle/orcl/pfile/initORCL.ora
В этом файле раскомментируем строчку, содержащую информацию о сегментах отката:
rollback_segments = (rbs01, rbs02, rbs03, rbs04)
Далее из admin.tgz (файл доступен по адресу http://pm.stu.lipetsk.ru/~oracle/admin.tgz
[oracle@matrix oracle]$ cd /usr/oracle/network/admin [oracle@matrix oracle]$ tar zxvf /tmp/admin.tgz
Тем самым в /usr/oracle/network/admin будут созданы файлы: listener.ora, sqlnet.ora и tnsnames.ora.
listener.ora и tnsnames.ora нужно исправить на предмет собственного доменного имени. У меня оно matrix.pm.lstu.
[oracle@matrix oracle]$ vim /usr/oracle/network/admin/listener.ora [oracle@matrix oracle]$ vim /usr/oracle/network/admin/tnsnames.ora
Для этого из-под root'а в /usr/local/etc/rc.d кладем файл oracle.sh из следующего архива: http://pm.stu.lipetsk.ru/~oracle/oracle.tgz
matrix# cd /usr/local/etc/rc.d matrix# tar zxfv /tmp/oracle.tgz
Создаем /usr/oracle/bin/start.db, следующего содержимого:
connect internal; startup pfile=$ORACLE_HOME/orcl/pfile/initORCL.ora; quit;
И /usr/oracle/bin/stop.db:
connect internal; shutdown normal; quit;
После чего можно попробывать запустить, экземпляр Oracle:
matrix# /usr/local/etc/rc.d/oracle.sh start
и зайти sqlplus'ом под пользователем demo:
[oracle@matrix oracle]$ sqlplus SQL*Plus: Release 8.1.7.0.0 - Production on Mon Jun 3 10:59:53 2002 (c) Copyright 2000 Oracle Corporation. All rights reserved. Enter user-name: demo Enter password: demo Connected to: Oracle 8i Enterprise Edition Release 8.1.7.0.1 - Production With the Partitioning option JServer Release 8.1.7.0.1 SQL> exit
Теперь гасим Oracle:
matrix# /usr/local/etc/rc.d/oracle.sh stop
И довольные, что только что совершили самое извратнейшее из всех возможных действо, перегружаем сервер.
matrix# reboot
Теперь, когда сервер вновь загрузится, Oracle 8i будет входить в стройный ряд ваших серверных приложений, работающих на FreeBSD!
1) Nick A. Leuta aka Skynick - за море времени, уделенное мне, за объяснение принципа работы линуксолятора, за помощь в работе с ним и updat'е его содержимого.
2) Yuriy Vostrikoff aka Mon - за ценный совет по ktrace
3) Oleg V. Volkov aka Rover - за любезную помощь в переводе с японского
4) Кафедру АСУ - за "добрые советы" снести FreeBSD и поставить Linux :)
5) www.tokuda.net - за статью, без которой врядли у меня хватило бы энтузиазма начать и довести до конца это дело.
Ну и конечно, особое Спасибо моей Натали, которая терпела все мои вчера, проведенные в институте до 22 вечера..
Если кто сочтет этот материал достойным быть где-то опубликованным, я буду только рад!
Если у кого-то получится (или наоборот, не получится) установить
Oracle 8i на FreeBSD - пишите!
Я сделал все возможное, чтобы эта
установка прошла без проблем.
© 2002 Stas Kornienko [email protected] 2:5036/32
Закладки на сайте Проследить за страницей |
Created 1996-2025 by Maxim Chirkov Добавить, Поддержать, Вебмастеру |