[Users] New engine install on remote DB fails "uuid-ossp extension is not loaded"
Ian Levesque
ian at crystal.harvard.edu
Tue Aug 14 18:20:21 UTC 2012
On Aug 14, 2012, at 12:58 PM, Yair Zaslavsky wrote:
> On 08/14/2012 07:12 PM, Ian Levesque wrote:
>> Hello,
>>
>> I'm trying to install oVirt 3.1, using an external postgres db running on RHEL6 (postgresql-server-8.4.12-1.el6_2.x86_64). I'm getting the following error during engine-setup:
>>
>> Error: uuid-ossp extension is not loaded into the DB.
>> Verify with the DB admin that uuid-ossp extension is loaded into newly created databases and rerun the setup.
>>
>> The database log indicates:
>>
>> ERROR: function uuid_generate_v1() does not exist at character 8
>> HINT: No function matches the given name and argument types. You might need to add explicit type casts.
>> STATEMENT: SELECT uuid_generate_v1();
>>
>> I did some searching, and it appeared that I might need to add some postgres-contrib functions:
>>
>> psql -U postgres -d engine -f /usr/share/pgsql/contrib/uuid-ossp.sql
>>
>> Unfortunately, it appears that the install script wants to create a temporary database and expects these functions to exist on its newly-created temp DB, not an already-existing database.
>
> Indeed this step is required for postgresql 8.4.x (you have to install this script).
> I did not encounter an issue with this script.
> I ran
>
> psql -U postgres -d engine -f /usr/share/pgsql/contrib/uuid-ossp.sql
>
> And the script execution went smoothly (this scripts runs instructions of create or replace function so it is re-entrant).
> Can you please elaborate more on the error you're getting?
Here's what the install log tells me:
2012-08-14 11:56:12::INFO::engine_validators::425::root:: Successfully created temp database on server cmcd-web.
2012-08-14 11:56:12::INFO::engine_validators::443::root:: Checking that uuid extension is loaded by default on the remote server
2012-08-14 11:56:12::DEBUG::common_utils::350::root:: running sql query 'SELECT uuid_generate_v1();' on db server: 'cmcd-web'.
2012-08-14 11:56:12::DEBUG::common_utils::286::root:: cmd = /usr/bin/psql -h cmcd-web -p 5432 -U ovirt -d ovirt_engine_test -c "SELECT uuid_generate_v1();"
2012-08-14 11:56:12::DEBUG::common_utils::291::root:: output =
2012-08-14 11:56:12::DEBUG::common_utils::292::root:: stderr = ERROR: function uuid_generate_v1() does not exist
So, the installer is trying to create a database "ovirt_engine_test" and succeeding. But until you run `psql -U postgres -d <database_name> -f /usr/share/pgsql/contrib/uuid-ossp.sql`, the function uuid_generate_v1() won't be available. Therefore, the temporary database the installer is using to determine compatibility fails.
Ian
More information about the Users
mailing list