sql >> Databáze >  >> RDS >> Mysql

Nelze nainstalovat mysqlclient na centos

Vyřešeno v CentOS 7 + MariaDB 10.2

Mám stejný problém a chtěl bych přispět svou odpovědí . Právě jsem nainstaloval na své 2 servery se systémem CentOS 7 s MariaDB (10.2.14-MariaDB MariaDB Server).

$ cat /etc/centos-release
CentOS Linux release 7.4.1708 (Core)

$ mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is XXXX
Server version: 10.2.14-MariaDB MariaDB Server

Nainstaloval jsem MariaDB, tyto balíčky:

$ yum list installed | grep mariadb
MariaDB-client.x86_64                   10.3.13-1.el7.centos           @mariadb
MariaDB-common.x86_64                   10.3.13-1.el7.centos           @mariadb
MariaDB-compat.x86_64                   10.3.13-1.el7.centos           @mariadb
MariaDB-server.x86_64                   10.3.13-1.el7.centos           @mariadb
galera.x86_64                           25.3.25-1.rhel7.el7.centos     @mariadb

Zjistil jsem, že problém je v tom, že mysqlclient vyžaduje balíčky mysql-devel, což se liší od mariadb-devel. Neinstalujte mariadb-devel!

Chcete-li tedy nainstalovat pouze mysql-devel, musíte:

1. Odeberte všechny MariaDB-devel

$ sudo yum erase MariaDB-devel.x86_64

2. Přidejte úložiště MySQL v yum

  1. Přejděte na https://dev.mysql.com/downloads/repo/yum/ a vyberte soubor RPM pro váš CentOS (pro mě jsem zvolil "Red Hat Enterprise Linux 7 / Oracle Linux 7 (Architecture Independent), RPM Package“ . Klikněte na "stáhnout" .)
  2. Stahujte bez registrace, zkopírujte spodní odkaz "Ne, děkuji, jen spusťte stahování" .
  3. Přejděte do svého terminálu a zadejte:
$ wget link-to-rpm-you-choose
  1. Po dokončení stahování zadejte:
$ sudo rpm -Uvh your-rpm-downloaded

3. Nyní nainstalujte mysql-devel

  1. Zadejte (toto je moje verze, sledujte svou):
$ sudo yum install mysql-community-devel.x86_64

4. Nyní konečně:mysqlclient

  1. Typ:
$  sudo pip install mysqlclient
Collecting mysqlclient
  Cache entry deserialization failed, entry ignored
  Cache entry deserialization failed, entry ignored
  Downloading https://files.pythonhosted.org/packages/f4/f1/3bb6f64ca7a429729413e6556b7ba5976df06019a5245a43d36032f1061e/mysqlclient-1.4.2.post1.tar.gz (85kB)
    100% |████████████████████████████████| 92kB 758kB/s
Installing collected packages: mysqlclient
  Running setup.py install for mysqlclient ... done
Successfully installed mysqlclient-1.4.2.post1
You are using pip version 8.1.2, however version 19.0.3 is available.
You should consider upgrading via the 'pip install --upgrade pip' command.

A je to! Fungovalo to jako kouzlo a teď mohu používat Python + Django + MariaDB/MySQL

Jo a mysqlclient je konektor doporučený Django. Viz:https://docs.djangoproject. com/en/2.1/ref/databases/#mysql-db-api-drivers

Hodně štěstí a uvidíme se! :-)



  1. Výjimka PDO „nelze najít ovladač“ v php

  2. Jak zjistit, zda hodnota obsahuje alespoň jedno číslo na serveru SQL

  3. MySQL správná syntaxe k použití blízko '' na řádku 1 chyby

  4. SQL Azure:Databáze XXXYYY na serveru momentálně není k dispozici