لقد عملت على النحو التالي:
اتباع استخدام حاوية Docker
- تثبيت قياسي لـ discourse. (https://github.com/discourse/discourse/blob/main/docs/INSTALL-cloud.md).
- تنزيل حاوية Docker الخاصة بـ MySQL وتحميل قاعدة بيانات vBulletin الخاصة بي إليها.
لقد تحققت من ذلك باستخدام الأمر<root@localhost:/opt/discourse# mysql -h 172.17.0.5 -P 3306 --protocol=tcp -u root -p>. root@localhost:/opt/discourse#./launcer enter app- فشل
apt-get update && apt-get install libmysqlclient-dev mysql-server-5.7.
لذلك قمت بتثبيتapt-get update && apt-get install libmariadb-dev mariadb-server - لا يمكنني تشغيل MySQL على Docker.
root@localhost-app:/var/www/discourse# mysql
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/run/mysqld /mysqld.sock' (2)
لا يوجد mysqld.sock في جميع مجلدات Docker. لم أتمكن من العثور عليه باستخدام أمر <find>.
root@localhost-app:/var/www/discourse# sudo service mysql start
mysql: unrecognized service
- لقد اطلعت على https://www.baeldung.com/docker-cant-connect-local-mysql واستخدمت صورة Docker الخاصة بـ MySQL على “172.17.0.5”.
gem install mysql2
gem install php_serialize
لم يعمل <gem install mysql2> حتى تم تثبيت libmariadb-dev.
8. تشغيل
su discourse -c 'bundle install --no-deployment --without test --without development --path vendor/bundle'
حدث خطأ، لذلك قمت بحذف gemfile.lock وملف .bundle وحاولت مرة أخرى.
9. بعد ذلك حاولت.
export DB_NAME="vb3" # Change this to the name of VB3 database.
export DB_USER="root"
export DB_PASSWORD="mypassword"
export DB_HOST="172.17.0.5"
cd /var/www/discourse
su discourse -c 'bundle exec ruby script/import_scripts/vbulletin.rb'
لكن النص البرمجي يولد خطأ.
1: from /var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-mini-profiler-3.0.0/lib/mini_profiler/profiling_methods.rb:83:in `profile_method'
/var/www/discourse/vendor/bundle/ruby/2.7.0/gems/rack-mini-profiler-3.0.0/lib/mini_profiler/profiling_methods.rb:83:in `alias_method': undefined method `call' for class `Redis::Client' (NameError)
Did you mean? caller
كيف يمكنني إصلاح ذلك؟
شكرا لك.