Uploading index definitions.
Error 400: --- begin server output ---
Creating a composite index failed: ascending single-property indexes are not necessary
--- end server output ---
2008年6月25日水曜日
ascending single-property indexes are not necessary
2008年6月24日火曜日
no matching index found
SDK 環境では徐々にデータを追加していったためか、あまり発生しなかったエラー
Cloud には bulkupload したためか、no matching index found エラーが多発する。
index.yaml に指定の内容を追加して update して対応。
Cloud には bulkupload したためか、no matching index found エラーが多発する。
index.yaml に指定の内容を追加して update して対応。
2008年6月23日月曜日
DeadlineExceededError
削除は手動で画面を Reload して繰り返し実行すればいいが
プログラムで LOOP させて offset を自動処理しては DeadlineExceededError はさけられず、
意味がない。
このあたり how should I clean up inside the datastore?
http://groups.google.com/group/google-appengine/browse_thread/thread/da854121e242755a?hl=en
でも話題になっているので、そのうち trauncate table のようなコマンドは用意されるか。
制限事項が多く、少々うんざり気味。
でも、RDBMS でも Undo 領域を必要としない truncate table ができるまでは Oracle などよく delete では「Rollbackセグメントが足りません」といってデータを思うように削除させてくれず、仕方がないので条件指定して少しづつ削除したこともあった。
Rollback などできなくていいから、まとめて削除させて欲しいと思いつつ。
r = db.GqlQuery("select * from Stock limit 100")
for rr in r:
rr.delete()
後方一致 ( like *key_word ) の場合、offset で移動させた。r = db.GqlQuery("select * from Model limit 100 offset " + str(offset) )
start = int(offset) + 100
self.response.out.write('<a href="/xxx?offset=%s">del</a>' % str(start) )
for rr in r:
if rr.trackback_url.find('</td></tr>') <>-1:
・・・
プログラムで LOOP させて offset を自動処理しては DeadlineExceededError はさけられず、
意味がない。
このあたり how should I clean up inside the datastore?
http://groups.google.com/group/google-appengine/browse_thread/thread/da854121e242755a?hl=en
でも話題になっているので、そのうち trauncate table のようなコマンドは用意されるか。
制限事項が多く、少々うんざり気味。
でも、RDBMS でも Undo 領域を必要としない truncate table ができるまでは Oracle などよく delete では「Rollbackセグメントが足りません」といってデータを思うように削除させてくれず、仕方がないので条件指定して少しづつ削除したこともあった。
Rollback などできなくていいから、まとめて削除させて欲しいと思いつつ。
untrusted app XXX cannot access app helloworld's data
BadRequestError: untrusted app XXX cannot access app helloworld's data
Reference Property の値( =Key ) をbulkupload
・・・
('stock', datastore_types.Key),
・・・
しようとして発生。
仮に upload できたとしても、意味がないのでコメントアウト。
Reference Property の値( =Key ) をbulkupload
・・・
('stock', datastore_types.Key),
・・・
しようとして発生。
仮に upload できたとしても、意味がないのでコメントアウト。
max execution time
put にしろ fetch にしろ1回の処理に制限がある。
bulkload は 100 件
fetch は 1,000 件
delete も 100 件程度
http://groups.google.com/group/google-appengine/browse_thread/thread/08548c43d692af63?hl=en
bulkload は 100 件
fetch は 1,000 件
delete も 100 件程度
> Is there any limit of execution time of scripts? If there is, how long
> is this max execution time for a function?
A few seconds, eight or ten seconds at the most.
> Is there any way to set the max_execution_time or functions like
> set_time_limit() in php?
I don't think so.
> If I want my script to execut in a long time to finish its job, maybe
> 20 mininuts, just looks like a service, is there any way in App
> Engine ?
Nope. Google App Engine is only designed for applications that can
respond to requests in under 300 ms or so.
http://groups.google.com/group/google-appengine/browse_thread/thread/08548c43d692af63?hl=en
2008年6月22日日曜日
fetch() returns a maximum of 1000 results
SDK 環境ではこの
1000件以上のデータがあっても、1000件までしか、検索結果を得ることができない
などという制限はなかったので、
実際にようやく bulkloader でデータを 投入してみてはじめて気がついた。
のようなことをすれば、1000 の先のデータにアクセスできるのか? とも思ったが、そんなことはできなかった。
http://code.google.com/appengine/docs/datastore/gqlqueryclass.html
Google I/O session videos posted with slides の
Working with Google App Engine Models に
Store counts を推奨するようなことが書かれて
いたので、ちょっと気になってはいたがけれども。
1000 件以内に収まる条件で管理しないと
どこまでデータがあるのかさえわからなくなるとは。
1000件以上のデータがあっても、1000件までしか、検索結果を得ることができない
などという制限はなかったので、
実際にようやく bulkloader でデータを 投入してみてはじめて気がついた。
SELECT * FROM model limit 100 offset 1000
のようなことをすれば、1000 の先のデータにアクセスできるのか? とも思ったが、そんなことはできなかった。
http://code.google.com/appengine/docs/datastore/gqlqueryclass.html
- The query has performance characteristics that correspond linearly with the offset amount plus the limit.
Note: fetch() returns a maximum of 1000 results. If more than 1000 entities match the query, and either no limit is specified or a limit larger than 1000 is used, only the first 1000 results are returned by fetch().
Google I/O session videos posted with slides の
Working with Google App Engine Models に
Store counts を推奨するようなことが書かれて
いたので、ちょっと気になってはいたがけれども。
1000 件以内に収まる条件で管理しないと
どこまでデータがあるのかさえわからなくなるとは。
2008年6月20日金曜日
Importing UTF-8 Data with Bulkloader
Importing UTF-8 Data
http://groups.google.com/group/google-appengine/browse_thread/thread/d4cf3013483220b5
を参考にいろいろ試したが、以下のパターンで UTF-8 が登録できたが、
str とタイプが決まってしまて、 datastore_types.Text にできなかったので
500 バイト以上の UTF-8 データについては別途検討。
myloader.py
bulkload をフォルダごとProjectフォルダにコピーして、__init__.py を加工。
bulkload/__init__.py
('name', lambda x: unicode(x,'utf-8')) をやめて、以下を追加すると
日本語がきれいに抜けて、英数字だけになる。
http://groups.google.com/group/google-appengine/browse_thread/thread/d4cf3013483220b5
を参考にいろいろ試したが、以下のパターンで UTF-8 が登録できたが、
str とタイプが決まってしまて、 datastore_types.Text にできなかったので
500 バイト以上の UTF-8 データについては別途検討。
myloader.py
#from google.appengine.ext import bulkload
import bulkload
・・・
class PersonLoader(bulkload.Loader):
def __init__(self):
# Our 'Person' entity contains a name string and an email
bulkload.Loader.__init__(self, 'Person',
[
# ('name', str),
('name', lambda x: unicode(x,'utf-8')),
('email', datastore_types.Email),
])
bulkload をフォルダごとProjectフォルダにコピーして、__init__.py を加工。
bulkload/__init__.py
・・・
buffer = StringIO.StringIO(data.encode('utf-8'))
・・・
('name', lambda x: unicode(x,'utf-8')) をやめて、以下を追加すると
日本語がきれいに抜けて、英数字だけになる。
# val = unicode(val, errors='ignore')
entity[name] = converter(val)
登録:
投稿 (Atom)
Swift UI チュートリアル Loading watchOS が終わらない?
Loading watchOS が終わらない? ディスク容量の残量が少ないので不要なシュミレーターを削除したとこころ watchOSのものが全部なくなってしまっていた。 WatchOS を削除して再度インストールしても復活せず。 Create a new simulator で ...
-
1. get_or_insert 自体がトランザクションなのでこれを含めたトランザクションを 作成しようとするとエラーとなる。 File "C:\Program Files\Google\google_appengine\google\appengine\api\...
-
新しいXcodeが使いたかったので MacOS15(Sequoia) にアップグレードしたところ、やはりApacheでPHPが動かなくなっていた。 結論としては brew, openssl, php, httpd を全て再度インストールしたところ動くようになった。 以下、作業ロ...
-
Apache が動かなくなった (MacOS 13.6.7) /var/log/apache2/access_log も error_log も出力されなくなっている $ sudo apachectl start すると以下のようなエラーとなった。 Load failed: ...