У меня есть приложение Flex, которое вызывает функцию, которая выполняет поиск в большой коллекции документов. В зависимости от поискового запроса пользователь может захотеть остановить запрос от flex.
Я хотел бы не только остановить гибкое приложение от ожидания запроса, но и остановить запрос CFC. Это возможно? Как лучше всего это сделать?





Вы можете программно завершать запросы с помощью <cfabort/> или <cfsetting requesttimeout = "0"/> - но это на стороне сервера CF, о чем я не думаю, что вы спрашиваете?
Завершение его удаленно ... ну, если у вас есть FusionReactor, мощь можно будет связаться с ним, используя Flex, и он прервет запрос за вас. (Вы, конечно, можете попытаться завершить запросы в FusionReactor, но действительно ли Flex может попросить FR остановить его ... вам придется спросить об этом в списке рассылки FR, если есть способ сделать это.)
Возможно, альтернативным решением является попытка спроектировать поиск так, чтобы он работал по нескольким запросам, но насколько это выполнимо, будет зависеть от того, что именно вы ищете.
Если вы используете ColdFusion 8, вы можете использовать тег <cfthread>. Вы можете запустить процесс поиска в его собственном потоке, а затем использовать удаленный вызов для завершения потока поиска по мере необходимости.
Я не думаю, что есть способ непосредственный остановить вызов страницы извне. Согласно документам, только сам поток и его родитель могут прервать данный поток.
Однако вы можете установить флаг для данного потока в общей области.
Допустим, вы вызываете метод, который запускает некоторую фоновую обработку. Он генерирует уникальный идентификатор потока и возвращает его вызывающей стороне. Поток ищет флаг (например) в области приложения, который говорит ему остановиться. Он проверяет на каждом этапе фонового процесса. Он может прерваться в любой момент, когда установлен флаг.
Чтобы установить флаг, добавьте метод прерывания, который принимает имя потока, который должен быть прерван, вместе с достаточной безопасностью, чтобы убедиться, что третья сторона не может просто начать убивать потоки.
Чтобы добавить к ответу Бена Дума, я включаю пример кода того, как это можно сделать. Существует несколько подходов и способов именования, организации и вызова приведенного ниже кода, но, надеюсь, это полезно.
В какой-то момент во время запуска запроса сохраните информацию о процессе в общей области и верните идентификатор клиенту. Вот примеры функций, которые можно использовать на страницах или удаленных запросах.
<cffunction name = "createProcess" output = "false">
<cfset var id = createUUID()>
<cfset application.processInfo[id] = {
progress = 0,
kill = false
}>
<cfreturn id />
</cffunction>
Затем клиент может проверить прогресс, опросив сервер, или отправить запрос на завершение процесса.
<cffunction name = "getProcessProgress" output = "false">
<cfargument name = "processID" required = "true">
<cfreturn application.processInfo[arguments.processID].progress />
</cffunction>
<cffunction name = "killProcess" output = "false">
<cfargument name = "processID" required = "true">
<cfset application.processInfo[arguments.processID].kill = true />
</cffunction>
Фактический рассматриваемый процесс на стороне сервера может затем обратиться к функции, например, во время цикла, чтобы проверить, следует ли прервать обработку и очистить любую работу, если это необходимо.
<cffunction name = "shouldKillProcess" output = "false">
<cfargument name = "processID" required = "true">
<cfreturn application.processInfo[arguments.processID].kill />
</cffunction>
Потоки работают в рамках одного запроса, а не между несколькими запросами?