Как установить службу Denodo OData во встроенный контейнер Tomcat в Denodo 5.5?

Я хотел бы установить пользовательскую службу OData во встроенный веб-контейнер Tomcat в Denodo 5.5.

Я обнаружил, что инструкции, которые предоставляет Денодо, несколько сбивают с толку, и поэтому я публикую сообщения в stackru и включаю ответ в надежде, что кто-то найдет это полезным.

1 ответ

Решение

Отключение Денодо

$DENODO_HOME/bin/vqlserver_shutdown.sh
sleep 15
ps -ef | grep denodo | grep -v grep

Получить Denodo OData Service.zip

Скачать Denodo OData Service.zip файл и распакуйте его в /tmp такой что у тебя есть:

/tmp/denodo-odata2-service-5.5-20160129

"Установите" службу OData

# copy the war file to the webapps folder
cp /tmp/denodo-odata2-service-5.5-20160129/denodo-odata2-service-5.5.war $DENODO_HOME/resources/apache-tomcat/webapps/

# Copy the odata xml to the embedded tomcat container
cp /tmp/denodo-odata2-service-5.5-20160129/scripts/denodo-odata2-service-5.5.xml $DENODO_HOME/resources/apache-tomcat/conf/DenodoPlatform-5.5/localhost/

# Copy the startup/shutdown scripts to the bin folder
cp /tmp/denodo-odata2-service-5.5-20160129/scripts/*.sh $DENODO_HOME/bin
chmod u+rwx $DENODO_HOME/bin/odata*.sh

# change the DENODO_HOME directory in the $DENODO_HOME/bin/odata*.sh scripts
vi $DENODO_HOME/bin/odata_service_startup.sh   # look for DENODO_HOME and update it
vi $DENODO_HOME/bin/odata_service_shutdown.sh  # look for DENODO_HOME and update it

Сделайте соответствующие изменения конфигурации

# Add a reference to the Denodo JAR in the catalina.properties file
vi $DENODO_HOME/resources/apache-tomcat/conf/catalina.properties
# Look for shared.loader
# Add this to the end of the shared.loader line:
${catalina.base}/../../lib/vdp-jdbcdriver-core/denodo-vdp-jdbcdriver.jar

# update the server.xml.template file to include a JNDI resource by putting the following in the <GlobalNamingResources> section
vi $DENODO_HOME/resources/apache-tomcat/conf/server.xml.template

<Resource name="jdbc/VDPdatabase"
    auth="Container"
    type="javax.sql.DataSource"
    username="admin" password="***********"
    url="jdbc:vdb://localhost:9999/admin"
    driverClassName="com.denodo.vdp.jdbc.Driver"
    initialSize="5" maxWait="5000"
    maxActive="120" maxIdle="5"
    validationQuery="select * from dual()"
    poolPreparedStatements="true"/>

# Change the permissions on server.xml.template so other people can't read your denodo admin password:
chmod go-rwx $DENODO_HOME/resources/apache-tomcat/conf/server.xml.template
chmod go-rwx $DENODO_HOME/resources/apache-tomcat/conf/server.xml

# update the context.xml to point to the JNDI resource in and also add the properties to the <Context> section (add all of the below to the <Context> section)
vi $DENODO_HOME/resources/apache-tomcat/conf/context.xml

<ResourceLink name="jdbc/VDPdatabase"
    global="jdbc/VDPdatabase"
    type="javax.sql.DataSource"/>

<Environment type="java.lang.String" name="odataserver.address" value="/denodo-odata.svc"/>
<Environment type="java.lang.Integer" name="server.pageSize" value="1000"/>
<Environment type="java.lang.Boolean" name="enable.adminUser" value="true"/>

Запустите его и убедитесь, что он работает

$DENODO_HOME/bin/vqlserver_startup.sh
# wait for Denodo and Tomcat to start

# deploy/start the odata webapp
$DENODO_HOME/bin/odata_service_startup.sh

# Go to 
http://hostname:9090/denodo-odata2-service-5.5/denodo-odata.svc/databasename
(but change "databasename" to your virtual database name)

Дополнительные соображения

Поскольку вы сейчас используете встроенный веб-контейнер Tomcat и в нем запущена служба odata, каждый раз, когда вы останавливаете / запускаете Denodo, вам также необходимо останавливать / запускать службу OData.

Остановка Денодо

  1. Во-первых, остановите службу OData через $DENODO_HOME/bin/odata_service_shutdown.sh
  2. Затем остановите Денодо через $DENODO_HOME/bin/vqlserver_shutdown.sh

Начиная Денодо

  1. Во-первых, запустите Denodo через $DENODO_HOME/bin/vqlserver_startup.sh
  2. Затем запустите службу OData через $DENODO_HOME/bin/odata_service_startup.sh

Доступ администратора

Если вы не хотите, чтобы пользователь с правами администратора имел доступ через odata, измените настройку в $DENODO_HOME/resources/apache-tomcat/conf/context.xml файл и перезагрузите.

Другие вопросы по тегам