सवाल संपूर्ण MySQL डेटाबेस डुप्लिकेट करें


क्या यह एक लिनक्स सर्वर पर एक संपूर्ण MySQL डेटाबेस डुप्लिकेट करने के लिए सकारात्मक है?

मुझे पता है कि मैं निर्यात और आयात का उपयोग कर सकता हूं लेकिन मूल डेटाबेस> 25 एमबी है, इसलिए यह आदर्श नहीं है।

क्या यह mysqldump का उपयोग कर या डेटाबेस फ़ाइलों को सीधे डुप्लिकेट कर सकता है?


76
2017-12-11 13:08


मूल




जवाब:


पहले डुप्लिकेट डेटाबेस बनाएं:

CREATE DATABASE duplicateddb;

सुनिश्चित करें कि उपयोगकर्ता और अनुमतियां सभी जगह पर हैं और:

 mysqldump -u admin -p originaldb | mysql -u backup -pPassword duplicateddb; 

151
2017-12-11 13:13



मुझे नहीं लगता कि आपकी दूसरी कमांड लाइन के दूसरे भाग में "-p" और "पासवर्ड" के बीच एक जगह होनी चाहिए
कोई जगह नहीं होनी चाहिए! उत्तर इस तरह सही है। MySQL मैन पेज ने कहा: --password [= password], -p [पासवर्ड] सर्वर से कनेक्ट करते समय उपयोग करने के लिए पासवर्ड। यदि आप शॉर्ट ऑप्शन फॉर्म (-पी) का उपयोग करते हैं, तो आपके पास विकल्प और पासवर्ड के बीच कोई जगह नहीं हो सकती है। यदि आप कमांड लाइन पर --password or -p विकल्प के बाद पासवर्ड मान को छोड़ देते हैं, तो MySQL एक के लिए संकेत देता है। कमांड लाइन पर पासवर्ड निर्दिष्ट करना असुरक्षित माना जाना चाहिए। खंड 6.1.2.1, "पी के लिए अंतिम उपयोगकर्ता दिशानिर्देश देखें ... - nils petersohn
ध्यान दें कि mysqldump डिफ़ॉल्ट रूप से ट्रिगर द्वारा बैक अप करता है लेकिन संग्रहित प्रक्रियाओं में नहीं, जोड़ता है --routines इस मामले के लिए एक विकल्प के रूप में। - LinuxDevOps
यदि आप इसे ऐसा कर रहे हैं और आप नहीं चाहते हैं कि इस उपयोगकर्ता का MySQL पासवर्ड बैश इतिहास में उपलब्ध हो, तो इसे अपने संपादित करें ~/.bash_history इसे निष्पादित करने के बाद फ़ाइल। या आप पहले कमांड के परिणाम को अस्थायी फ़ाइल में आउटपुट भी कर सकते हैं और उसके बाद निम्नलिखित निष्पादित कर सकते हैं (जो आपको पासवर्ड से संकेत देगा) mysql -p -u admin duplicatedb < temporaryfile.sql। - Mike
यह उत्तर निश्चित रूप से काम करता है, लेकिन सवाल बताता है "मुझे पता है कि मैं निर्यात और आयात का उपयोग कर सकता हूं लेकिन मूल डेटाबेस> 25 एमबी है, इसलिए यह आदर्श नहीं है" और यह उत्तर मूल रूप से निर्यात और आयात करता है। - el.pescado


दूरस्थ सर्वर के लिए

mysqldump mydbname | ssh host2 "mysql mydbcopy"

स्थानीय सर्वर के लिए

mysqldump mydbname | mysql mydbcopy

15
2017-12-11 13:12



त्रुटि 1064 (42000): आपको अपने SQL वाक्यविन्यास में कोई त्रुटि है; हाय, स्थानीय सर्वर में कमांड का उपयोग करते समय त्रुटि दिखा रहा है, कृपया मदद करें - amit_game
stackoverflow.com/questions/23446377/... - Peter Lindqvist


मैं कभी-कभी एक mysqldump करता हूं और आउटपुट को किसी अन्य डेटाबेस में आयात करने के लिए किसी अन्य mysql कमांड में पाइप करता हूं।

mysqldump --add-drop-table -u wordpress -p wordpress | mysql -u wordpress -p wordpress_backup

5
2017-12-11 13:10



मुझे एक त्रुटि मिलती है कि जब मैं इसका उपयोग करता हूं तो dest डेटाबेस मौजूद नहीं होता है। तो, आपको एक CREAT डेटाबेस लाइन भी चाहिए। - blak3r
बहुत आसान, धन्यवाद! - Sumit Bisht


सिस्टम में एक mysqldump फ़ाइल बनाएं जिसमें डेटा है और पाइप का उपयोग इस mysqldump फ़ाइल को नए सिस्टम में इनपुट के रूप में देने के लिए करें। एसएस कमांड का उपयोग कर नई प्रणाली को जोड़ा जा सकता है।

mysqldump -u user -p'password' db-name | ssh user@some_far_place.com mysql -u user -p'password' db-name

-पी [पासवर्ड] के बीच कोई जगह नहीं


3
2018-05-06 13:25



क्या आप यह वर्णन कर सकते हैं कि यह कैसे काम करता है, उदा। पाइप का उपयोग? - kalyfe


यहां एक विंडोज़ बैट फ़ाइल है जो मैंने लिखा है जो विन्सेंट और पॉल्स के सुझावों को जोड़ती है। यह उपयोगकर्ता को स्रोत और गंतव्य नामों के लिए संकेत देता है।

अपने निष्पादन योग्य / डेटाबेस बंदरगाहों के उचित पथ सेट करने के लिए बस शीर्ष पर चर को संशोधित करें।

:: Creates a copy of a database with a different name.
:: User is prompted for Src and destination name.
:: Fair Warning: passwords are passed in on the cmd line, modify the script with -p instead if security is an issue.
:: Uncomment the rem'd out lines if you want script to prompt for database username, password, etc.

:: See also: http://stackoverflow.com/questions/1887964/duplicate-entire-mysql-database

@set MYSQL_HOME="C:\sugarcrm\mysql\bin"
@set mysqldump_exec=%MYSQL_HOME%\mysqldump
@set mysql_exec=%MYSQL_HOME%\mysql
@set SRC_PORT=3306
@set DEST_PORT=3306
@set USERNAME=TODO_USERNAME
@set PASSWORD=TODO_PASSWORD

:: COMMENT any of the 4 lines below if you don't want to be prompted for these each time and use defaults above.
@SET /p USERNAME=Enter database username: 
@SET /p PASSWORD=Enter database password: 
@SET /p SRC_PORT=Enter SRC database port (usually 3306): 
@SET /p DEST_PORT=Enter DEST database port: 

%MYSQL_HOME%\mysql --user=%USERNAME% --password=%PASSWORD% --port=%DEST_PORT% --execute="show databases;"
@IF NOT "%ERRORLEVEL%" == "0" GOTO ExitScript

@SET /p SRC_DB=What is the name of the SRC Database:  
@SET /p DEST_DB=What is the name for the destination database (that will be created):  

%mysql_exec% --user=%USERNAME% --password=%PASSWORD% --port=%DEST_PORT% --execute="create database %DEST_DB%;"
%mysqldump_exec% --add-drop-table --user=%USERNAME% --password=%PASSWORD% --port=%SRC_PORT% %SRC_DB% | %mysql_exec% --user=%USERNAME% --password=%PASSWORD% --port=%DEST_PORT% %DEST_DB%
@echo SUCCESSFUL!!!
@GOTO ExitSuccess

:ExitScript
@echo "Failed to copy database"
:ExitSuccess

नमूना उत्पादन:

C:\sugarcrm_backups\SCRIPTS>copy_db.bat
Enter database username: root
Enter database password: MyPassword
Enter SRC database port (usually 3306): 3308
Enter DEST database port: 3308

C:\sugarcrm_backups\SCRIPTS>"C:\sugarcrm\mysql\bin"\mysql --user=root --password=MyPassword --port=3308 --execute="show databases;"
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sugarcrm_550_pro   |
| sugarcrm_550_ce    |
| sugarcrm_640_pro   |
| sugarcrm_640_ce    |
+--------------------+
What is the name of the SRC Database:  sugarcrm
What is the name for the destination database (that will be created):  sugarcrm_640_ce

C:\sugarcrm_backups\SCRIPTS>"C:\sugarcrm\mysql\bin"\mysql --user=root --password=MyPassword --port=3308 --execute="create database sugarcrm_640_ce;"

C:\sugarcrm_backups\SCRIPTS>"C:\sugarcrm\mysql\bin"\mysqldump --add-drop-table --user=root --password=MyPassword --port=3308 sugarcrm   | "C:\sugarcrm\mysql\bin"\mysql --user=root --password=MyPassword --port=3308 sugarcrm_640_ce
SUCCESSFUL!!!

1
2018-03-07 02:28





यह InnoDB के लिए काम नहीं करेगा। यदि आप MyISAM डेटाबेस कॉपी करने का प्रयास कर रहे हैं तो केवल इस वर्कअराउंड का उपयोग करें।

यदि बैकअप के दौरान तालिकाओं को लॉक करना है, और संभवतः, डेटाबेस आयात के दौरान MySQL को रोकना स्वीकार्य है, mysqlhotcopy तेजी से काम कर सकते हैं।

जैसे

बैकअप:

# mysqlhotcopy -u root -p password db_name /path/to/backup/directory

पुनर्स्थापित करें:

cp /path/to/backup/directory/* /var/lib/mysql/db_name

mysqlhotcopy एसएसएच (एसपीपी), और संभवतः सीधे डुप्लिकेट डेटाबेस निर्देशिका में फ़ाइलों को स्थानांतरित कर सकते हैं।

जैसे

# mysqlhotcopy -u root -p password db_name /var/lib/mysql/duplicate_db_name

1
2018-01-22 20:52





डेटाबेस की एक प्रति बनाना

# mysqldump -u root -p password db1 > dump.sql
# mysqladmin -u root -p password create db2
# mysql -u root -p password db2 < dump.sql

1
2017-12-19 08:53





यह मेरे लिए कमांड प्रॉम्प्ट के साथ काम करता है, OUTSIDE mysql खोल से:

# mysqldump -u root -p password db1 > dump.sql
# mysqladmin -u root -p password create db2
# mysql -u root -p password db2 < dump.sql

यह मेरे लिए सबसे अच्छा तरीका दिखता है। यदि "dump.sql" को ज़िपित करना है तो आप इसे संपीड़ित बैकअप के रूप में संग्रहीत कर सकते हैं। ठंडा! इनोडब टेबल के साथ 1 जीबी डेटाबेस के लिए, "dump.sql" बनाने के लिए लगभग एक मिनट, और नए डीबी डीबी 2 में डेटा डंप करने के लिए लगभग तीन मिनट।

सीधे छेद डीबी निर्देशिका (mysql / data / db1) की प्रतिलिपि बनाने के लिए मेरे लिए काम नहीं किया, मुझे लगता है कि InnoDB तालिकाओं की वजह से।


0
2018-03-18 18:31