Kiedy czyta się o dokumentację PLAY2 Znalazłem to:Próbując wykorzystać Akka przyszłych i zabaw obietnic w mojej aplikacji PLAY2
Ze względu na sposób Zagraj 2.0 dzieła, kod działania muszą być jak najszybciej możliwe (tj. bez blokowania). Co więc powinniśmy zwrócić w wyniku, jeśli nie będziemy w stanie go jeszcze obliczyć? Odpowiedź powinna być obietnicą rezultatu: !
Wow! To oczywiście sprawiło, że zainteresowałem się playakka i akka. Aktualnie buduję aplikację do autouzupełniania, która integruje się z elastycznym wyszukiwaniem, , więc byłoby to idealne dopasowanie!
Kontroler:
public class AutoComplete extends Controller {
@BodyParser.Of(value = BodyParser.Json.class)
public static Result complete(final String term) {
F.Promise<List<String>> list = Akka.future(new Callable<List<String>>() {
public List<String> call() throws Exception {
List<String> list = IndexService.find(term);
return list;
}
});
return async(list.map(new F.Function<List<String>, Result>() {
@Override
public Result apply(List<String> list) throws Throwable {
return ok(Json.toJson(list));
}
}));
}
Usługa:
public static List<String> find(final String term) {
IndexQuery <SearchWord> query = SearchWord.find.query();
query.setQuery("{\n" +
" \"bool\": {\n" +
" \"should\": [\n" +
" {\n" +
" \"text\": {\n" +
" \"search_word.ngrams\": {\n" +
" \"operator\": \"and\",\n" +
" \"query\": \""+term+"\"\n" +
" }\n" +
" }\n" +
" },\n" +
" {\n" +
" \"text\": {\n" +
" \"search_word.full\": {\n" +
" \"boost\": 1,\n" +
" \"query\": \""+term+"\"\n" +
" }\n" +
" }\n" +
" }\n" +
" ]\n" +
" }\n" +
"}");
IndexResults<SearchWord> indexResults = SearchWord.find.search(query);
List<String> list = new ArrayList<String>();
for(SearchWord word : indexResults.getResults()){
list.add(word.getWord());
}
return list;
}
}
Searchword:
@IndexType(name = "search_word")
public class SearchWord extends Index {
// Find method static for request
public static Index.Finder<SearchWord> find = new Index.Finder<SearchWord>(SearchWord.class);
public enum WordType {
NAME,
STRONG_SEARCH_WORD,
WEAK_SEARCH_WORD,
BANNED
}
private String word;
private WordType wordType;
public SearchWord() {
}
public SearchWord(IndexWord indexWord) {
super.id = ""+indexWord.getId();
this.word = StringUtils.lowerCase(indexWord.getWord());
this.wordType = WordType.valueOf(indexWord.getType());
}
public String getId() {
return super.id;
}
public void setId(String id) {
super.id = id;
}
public String getWord() {
return word;
}
public void setWord(String word) {
this.word = word;
}
public WordType getWordType() {
return wordType;
}
public void setWordType(WordType wordType) {
this.wordType = wordType;
}
@Override
public Map toIndex() {
HashMap map = new HashMap();
map.put("id", super.id);
map.put("word", word);
map.put("word_type", wordType.toString());
return map;
}
@Override
public Indexable fromIndex(Map map) {
if (map == null) {
return this;
}
this.word = (String) map.get("word");
this.wordType = WordType.valueOf((String)map.get("word_type"));
return this;
}
}
Kod działa bardzo dobrze, ale muszę powiedzieć, że nie jestem pewien, czy poprawnie to zaimplementowałem. Naprawdę staram się zrozumieć dokumentację. Moje pytania są w zasadzie następujące:
- Czy poprawnie wdrożyłem Przyszłość i obietnicę?
- Byłoby lepiej, aby utworzyć niestandardową aktora, w tym aktor przeprowadzić przeszukiwanie indeksu , jak przykładowo w docs:
=====
return async(
Akka.asPromise(ask(myActor,"hello", 1000)).map(
new Function<Object,Result>() {
public Result apply(Object response) {
return ok(response.toString());
}
}
)
);
- Może masz jakiś świetny przykład, którego jeszcze nie znalazłem?
Mam tylko pytania: (a) jaka jest zaleta asynchronicznego kodu w przypadku autouzupełniania? (b) czy jakakolwiek znacząca aktywność procesora zostanie zablokowana w przypadku braku asynchronicznego kodu? i (c) czy podejmujecie środki przeciwko złożeniu obietnic w złej kolejności? –