質問編集履歴
4
typo
test
CHANGED
File without changes
|
test
CHANGED
@@ -198,4 +198,4 @@
|
|
198
198
|
|
199
199
|
|
200
200
|
|
201
|
-
以上により、私には使えないと判断しました。(使えそうと報告していた
|
201
|
+
以上により、私には使えないと判断しました。(使えそうと報告していたので訂正まで。)
|
3
追記
test
CHANGED
File without changes
|
test
CHANGED
@@ -171,3 +171,31 @@
|
|
171
171
|
バージョン3.02をWindows+BitNami環境で使ってみました。UnDoやRollBackはうまく動きませんでしたが、Gitで直接resetすれば戻りました。また、Gitでのブランチ切り替えやマージも動作しました。別のブランチで行った2つの投稿がちゃんとマージされました。(びっくりです。)
|
172
172
|
|
173
173
|
まだ若いソフトのようなので問題はそれなりにありそうですが、大事な部分はきちんと使えそうです。
|
174
|
+
|
175
|
+
|
176
|
+
|
177
|
+
---
|
178
|
+
|
179
|
+
【追記】
|
180
|
+
|
181
|
+
VersionPressを運用してみましたが、結局使えないと判断しました。
|
182
|
+
|
183
|
+
|
184
|
+
|
185
|
+
①データベース内にバイナリなテーブルを作る。
|
186
|
+
|
187
|
+
これが原因でWordMoveでpushできなくなります。
|
188
|
+
|
189
|
+
mysqldumpで保存後削除してpush→回復すれば行けるとは思います。
|
190
|
+
|
191
|
+
|
192
|
+
|
193
|
+
②ちょっと修正する度にcommitする。
|
194
|
+
|
195
|
+
そこで、一旦無効化して使った場合、無効化以前へ戻すことができませんでした。
|
196
|
+
|
197
|
+
これでは意味がないです。
|
198
|
+
|
199
|
+
|
200
|
+
|
201
|
+
以上により、私には使えないと判断しました。(使えそうと報告していたきで訂正まで。)
|
2
追記
test
CHANGED
File without changes
|
test
CHANGED
@@ -127,3 +127,47 @@
|
|
127
127
|
mysqldumpのパスはBitNamiがインストールする場所を前提としています。
|
128
128
|
|
129
129
|
phpもワードプレスのプラグインも初めてなので、色々可笑しいかも。
|
130
|
+
|
131
|
+
|
132
|
+
|
133
|
+
---
|
134
|
+
|
135
|
+
【追記】
|
136
|
+
|
137
|
+
結局、mysqldumpされるものではGit管理できませんでした。
|
138
|
+
|
139
|
+
|
140
|
+
|
141
|
+
まず、リストアが異常に遅いです。これはWordMoveのオプションを参考にして数秒程度でリストアできるようになりました。
|
142
|
+
|
143
|
+
次にテーブルが全て1行になってしまう問題が発生しました。Gitでマージする際に直ぐにコンフリクトしてしまいます。
|
144
|
+
|
145
|
+
mysqldump時に`-c --order-by-primary --skip-extended-insert`オプションを付けて投稿ごとに改行されるようになりました。
|
146
|
+
|
147
|
+
|
148
|
+
|
149
|
+
しかし、投稿にPRIMARY keyが記録され、別ブランチで生成した投稿に同じPRIMARY keyが割り当てられてしまいます。これがGitでコンフリクトします。
|
150
|
+
|
151
|
+
手動で解決も不可能ではないですが、あまり現実的な気がしません。
|
152
|
+
|
153
|
+
|
154
|
+
|
155
|
+
---
|
156
|
+
|
157
|
+
再度、プラグインを探してみたところ、[VersionPress](http://mrlittlebig.com/blog/1032-2/)が見つかりました。(前回、結構探したのですが、ノイズが多すぎて見つからなかったようです。)
|
158
|
+
|
159
|
+
|
160
|
+
|
161
|
+
データベースの中身は、wordpress/wp-content/vpdb/の下に投稿毎にファイルを分けて保存され、しかも、投稿の改行も再現されてました。なのでGitのバージョン管理で期待通りにマージできそうです。
|
162
|
+
|
163
|
+
|
164
|
+
|
165
|
+
VersionPressが知らないPluginがデータベースへ保存しているデータ等はちゃんと管理できないかもしれませんが、そのような設定のマージが必要になるケースは稀でしょう。新しい方の上書きでコンフリクトを解決すれば概ねOKの筈です。
|
166
|
+
|
167
|
+
しかも、有り難いことにGPLv3での配布でした。GitHubからダウンロードできました。
|
168
|
+
|
169
|
+
|
170
|
+
|
171
|
+
バージョン3.02をWindows+BitNami環境で使ってみました。UnDoやRollBackはうまく動きませんでしたが、Gitで直接resetすれば戻りました。また、Gitでのブランチ切り替えやマージも動作しました。別のブランチで行った2つの投稿がちゃんとマージされました。(びっくりです。)
|
172
|
+
|
173
|
+
まだ若いソフトのようなので問題はそれなりにありそうですが、大事な部分はきちんと使えそうです。
|
1
追記
test
CHANGED
File without changes
|
test
CHANGED
@@ -33,3 +33,97 @@
|
|
33
33
|
この辺の情報をネットで見つけることができなかったのですが、WordMoveの設定ファイルを見るとGitのファイル群を同期から外すようデフォルトで設定されているので、WordMoveとGitでWordpressのデータを管理している人はそこそこ居るはずなのです。なので、きっと同じ問題を既に解決している人が居るはずなのですが、見つけることができません。
|
34
34
|
|
35
35
|
ヒントだけでもぜひ教えて下さい。
|
36
|
+
|
37
|
+
|
38
|
+
|
39
|
+
---
|
40
|
+
|
41
|
+
【解決】
|
42
|
+
|
43
|
+
下記プラグインで動作しました。
|
44
|
+
|
45
|
+
|
46
|
+
|
47
|
+
```php
|
48
|
+
|
49
|
+
<?php
|
50
|
+
|
51
|
+
/*
|
52
|
+
|
53
|
+
Plugin Name: save data-base
|
54
|
+
|
55
|
+
Plugin URI:
|
56
|
+
|
57
|
+
Description: 投稿されたらデータベースを保存する
|
58
|
+
|
59
|
+
Version: 1.0.0
|
60
|
+
|
61
|
+
License: GPL2
|
62
|
+
|
63
|
+
*/
|
64
|
+
|
65
|
+
function save_db($post_id, $post, $update)
|
66
|
+
|
67
|
+
{
|
68
|
+
|
69
|
+
if (wp_is_post_revision($post_id))
|
70
|
+
|
71
|
+
{
|
72
|
+
|
73
|
+
return;
|
74
|
+
|
75
|
+
}
|
76
|
+
|
77
|
+
|
78
|
+
|
79
|
+
$url=home_url('/');
|
80
|
+
|
81
|
+
$token=strtok($url, ":");
|
82
|
+
|
83
|
+
$token=strtok(":");
|
84
|
+
|
85
|
+
if ($token != "//localhost/")
|
86
|
+
|
87
|
+
{
|
88
|
+
|
89
|
+
return;
|
90
|
+
|
91
|
+
}
|
92
|
+
|
93
|
+
|
94
|
+
|
95
|
+
$dbHost = "ホスト名";
|
96
|
+
|
97
|
+
$dbUser = "ユーザ名";
|
98
|
+
|
99
|
+
$dbPass = "バスワード";
|
100
|
+
|
101
|
+
$dbName = "データベース名";
|
102
|
+
|
103
|
+
|
104
|
+
|
105
|
+
$filePath = ABSPATH."wp-content/";
|
106
|
+
|
107
|
+
$fileName = 'database.sql';
|
108
|
+
|
109
|
+
$mysqldump = ABSPATH."../../../mysql/bin/mysqldump ";
|
110
|
+
|
111
|
+
$command = $mysqldump.$dbName." --host=".$dbHost." --user=".$dbUser." --password=".$dbPass." > ".$filePath.$fileName;
|
112
|
+
|
113
|
+
system($command);
|
114
|
+
|
115
|
+
}
|
116
|
+
|
117
|
+
add_action('save_post', 'save_db', 10, 3);
|
118
|
+
|
119
|
+
|
120
|
+
|
121
|
+
?>
|
122
|
+
|
123
|
+
```
|
124
|
+
|
125
|
+
|
126
|
+
|
127
|
+
mysqldumpのパスはBitNamiがインストールする場所を前提としています。
|
128
|
+
|
129
|
+
phpもワードプレスのプラグインも初めてなので、色々可笑しいかも。
|