I make it work with your configuration code as part of the GAE project and with the dev server.
I used version 2.3.1 Restlet / version 1.9.18 GAE and the following code as a client:
public static void main(String[] args) { int i = 0; try { while (i < 30) { ClientResource cr = new ClientResource("http://localhost:8080/test"); Representation repr = cr.get(); System.out.println(">> call #"+i); Thread.sleep(100); i++; } } catch (Exception ex) { System.out.println(">> call #" + i + " failed"); ex.printStackTrace(); } }
I have the following exception after the 10th call:
>> call #0 >> call #1 >> call #2 >> call #3 >> call #4 >> call #5 >> call #6 >> call #7 >> call #8 >> call #9 >> call #10 failed 429 (429) - The server is refusing to service the request because the user has sent too many requests in a given amount of time ("rate limiting") at org.restlet.resource.ClientResource.doError(ClientResource.java:590) at org.restlet.resource.ClientResource.handleInbound(ClientResource.java:1153) at org.restlet.resource.ClientResource.handle(ClientResource.java:1048) at org.restlet.resource.ClientResource.handle(ClientResource.java:1023) at org.restlet.resource.ClientResource.handle(ClientResource.java:928) at org.restlet.resource.ClientResource.get(ClientResource.java:636) at org.restlet.gae.test.GaeRestletClient.main(GaeRestletClient.java:15)
Hope this helps you, Thierry
source share