0 / 0 / 0
Регистрация: 03.04.2013
Сообщений: 5

Word automation + Windows server 2008 R2 = тормоза(очень сильные тормоза)

03.04.2013, 11:50. Показов 2554. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Есть код, написанный правда на делфи, который экспортирует содержимое ТХТ файла в DOS кодировке в WORD. Попутно, если это необходимо, в экпортируемый текст вставляется штрих код для последующей идентификации документа. Так вот.... Данная программка прекрасно работает на следующих операц. системах - Win XP, Win 7, Win2003. Но при работе под Win 2008 server R2 получаем тормоз причем "конкретный". Простое открытие текстового файла с преобразованием кодировки на Win XP, Win 7, Win2003 происходит практически мнгновенно, а на Win 2008 server R2 получаем время 7-8 сек. А если в много страничный документ надо встроить штрих код, который проставляется на каждой странице, то ожидание формирования документа под Win 2008R2 затягивается на ~4мин против 6-7 сек. под управлением других операционок. Может кто сталкивался с данной проблемой.
Использую WORD 2007. Пробовал ставить WORD 2010- результат тот же....
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.04.2013, 11:50
Ответы с готовыми решениями:

Очень сильные тормоза при запуске отладчика
У меня VS 2017, в коде 550 строк текста, когда запускаю дебаг хоть по ф5, хоть по ф10, хоть как - висит минут 10 прежде чем у первой строки...

Сильные тормоза компьютера
Системе чуть не хватает до года. Захламлена, куча установленного и удаленного софта, а потому ужасно тормозит... даже если ничего не...

С сегодняшнего утра сильные тормоза
Привет. С новым годом. Не помню, что я вчера делал. Вроде всё как обычно. Но сегодня компьютер тормозит очень. Я уж думал не...

9
Модератор
 Аватар для vxg
3404 / 2175 / 353
Регистрация: 13.01.2012
Сообщений: 8,436
03.04.2013, 12:03
если есть код - запустить в режиме отладки и поглядеть где место с тормозами
0
0 / 0 / 0
Регистрация: 03.04.2013
Сообщений: 5
03.04.2013, 12:17  [ТС]
Вот кусок кода который ищет в тексте "маячок" и преобразует цифры в другой шрифт(шрифт штрих кода), он хоть на делфи но читается легко:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
while true do
     begin
       Docum.ActiveWindow.Selection.Find.ClearFormatting;
       Docum.ActiveWindow.Selection.Find.Text := WideString(chr(27)+'EAN');
 
       if Docum.ActiveWindow.Selection.Find.Execute(EmptyParam,EmptyParam,EmptyParam,EmptyParam,
           EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,
                                               EmptyParam,EmptyParam,EmptyParam,EmptyParam) = false then Break;
       Docum.ActiveWindow.Selection.End := Docum.ActiveWindow.Selection.End + 4;
       str := Docum.ActiveWindow.Selection.Text;
       len := StrToInt(Copy(str,5,2));
       size := StrToFloat(Copy(str,7,2));
       Docum.ActiveWindow.Selection.End := Docum.ActiveWindow.Selection.End + 1;
       Docum.ActiveWindow.Selection.Delete;
    
       Docum.ActiveWindow.Selection.End := Docum.ActiveWindow.Selection.End + len;
       Docum.ActiveWindow.Selection.CreateTextbox;
       Docum.ActiveWindow.Selection.ShapeRange.TextFrame.AutoSize := true;
       Docum.ActiveWindow.Selection.ShapeRange.TextFrame.WordWrap := False;
 
       Docum.ActiveWindow.Selection.ShapeRange.TextFrame.MarginLeft := 0;
       Docum.ActiveWindow.Selection.ShapeRange.TextFrame.MarginRight := 0;
       Docum.ActiveWindow.Selection.ShapeRange.TextFrame.MarginTop := 0;
       Docum.ActiveWindow.Selection.ShapeRange.TextFrame.MarginBottom := 0;
       Docum.ActiveWindow.Selection.WholeStory;
       Docum.ActiveWindow.Selection.Font.Name := 'C39HrP24DhTt'; //'EanGnivc';
       Docum.ActiveWindow.Selection.Font.Size := size;
       Docum.ActiveWindow.Selection.ShapeRange.WrapFormat.AllowOverlap := True;
       Docum.ActiveWindow.Selection.ShapeRange.WrapFormat.Side := wdWrapBoth;
       Docum.ActiveWindow.Selection.ShapeRange.WrapFormat.DistanceTop := 0;
       Docum.ActiveWindow.Selection.ShapeRange.WrapFormat.DistanceBottom := 0;
       Docum.ActiveWindow.Selection.ShapeRange.WrapFormat.DistanceLeft := 0;
       Docum.ActiveWindow.Selection.ShapeRange.WrapFormat.DistanceRight := 0;
       Docum.ActiveWindow.Selection.ShapeRange.WrapFormat.Type := 3;
       Docum.ActiveWindow.Selection.ShapeRange.Line.Visible := False;
       Docum.ActiveWindow.Selection.HomeKey(Unit:=wdStory);
     end;
Замерил скорость выполнения данного куска - Время выполения одного прохода менее полусекунды под WinXP, Win7, Win2003 и ~8 сек. под Win 2008 R2. Что сие может значить?

Конкретного тормоза в какойлибо строке не обнаружено. Просто каждое действие под Win2008 делается более медленно.
0
Модератор
 Аватар для vxg
3404 / 2175 / 353
Регистрация: 13.01.2012
Сообщений: 8,436
03.04.2013, 12:36
мб попробовать заменить Docum.ActiveWindow.Selection на переменную?
0
0 / 0 / 0
Регистрация: 03.04.2013
Сообщений: 5
05.04.2013, 10:09  [ТС]
Получается дело как бы и не в операционке. Т.к. установив её(Win 2008) на обычный комп( Pentium G620, RAM 2Gb ) получил время формирования 4-5 сек. Установил Win2003 на сервер - два четырех ядерных XEONa, RAM 16Gb, Raid - получил время формирования ~4мин.

В общем по результатам экспериментов выявлено что Word automation адекватно работает только на обычных DESKTOPах (обычние бытовые компьютеры), как только пытаемся работать на какой либо серверной платформе получаем тормоз...
0
Модератор
 Аватар для vxg
3404 / 2175 / 353
Регистрация: 13.01.2012
Сообщений: 8,436
05.04.2013, 10:28
все же попробуйте свернуть кучу точек в одну переменную. может на серве указатели очень длинные и он их разрешает долго.
0
0 / 0 / 0
Регистрация: 03.04.2013
Сообщений: 5
05.04.2013, 10:36  [ТС]
Данную оптимизацию сделал вчера вечером. Получил почти двукратное сокращение времени формирования. С четырех минут до почти двух минут. Но как получается это не решает проблему. Две минуты тоже очень долго, против двух- трех секунд на обычном десктопе.
0
Модератор
 Аватар для vxg
3404 / 2175 / 353
Регистрация: 13.01.2012
Сообщений: 8,436
05.04.2013, 11:20
но! вы видите, что в этом что-то есть. дальнейшую свертку пробовали делать? я имею ввиду конструкции вида .ShapeRange.TextFrame так же заменять на одну ссылку. то есть что бы везде где используется "трехэтажный" доступ стояли простые ссылки и был доступ только к полям.
0
0 / 0 / 0
Регистрация: 03.04.2013
Сообщений: 5
05.04.2013, 15:24  [ТС]
VXG - доработку предложенную Вами я сделал еще вчера.

Удалось сократить время формирования до 45 сек, но это больше напоминает "подгон под ответ" чем сколь нибудь рабочее решение: MsWord.Visible:= True плюс MsWord.ScreenUpdating:= False плюс приоритет потока работающего с ВОРДом - tpHighest....

Может быть скажу глупость, конечно, но возникает ощущение того что на скорость формирования документа сильно влияет видеоподсистема установленная на компьютере, но проверить это смогу только в понедельник. На сереверах стоят видекарты по принципу - лишь бы что то показывало.....
0
Модератор
 Аватар для vxg
3404 / 2175 / 353
Регистрация: 13.01.2012
Сообщений: 8,436
05.04.2013, 15:28
видеосистема влияет само собой если вы делаете нечто что отображается на экране. делайте все в невидимом документе. хотя не факт что поможет.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.04.2013, 15:28
Помогаю со студенческими работами здесь

Два сетевых интерфейса. Сильные тормоза
Добрый день! Имеются две сетевухи. подключены к разным сетям. Одна из них имеет доступ в Инет(enp4s0), вторая просто торчит во...

Сильные тормоза при работе с потоком
static void Main(string args) { getProcess(); Thread t = new Thread(reader); t.Start();...

Сильные тормоза при запуске системы
Здравствуйте.У знакомого проблемы с Вин 7.Вечером сидел в интернете волшебным образом не заметил как отключился антивирус и вследствии...

Сильные тормоза компьютера. Грузит проц
Доброго времени суток. Мне знакомый дал свой компьютер "почистить" т.к. говорит вдруг резко начал тормозить, видео не посмотреть, музыку не...

Сильные тормоза при подключении монитора
Доброго времени суток. Имею в использовании ноутбук asus n56 и монитор AOC с FullHD разрешением. Подключаю монитор к ноутбуку через...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Опции темы

Новые блоги и статьи
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1 У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\ А в самом низу файла-профиля. . .
PowerShell и онлайн сервисы. Валюта (floatrates.com руб.)
iNNOKENTIY21 11.11.2025
PowerShell функция floatrates-rub Примеры вызова: # Указанная валюта 'EUR' floatrates-rub -Code 'EUR' # Список имеющихся кодов валют floatrates-rub -Available function floatrates-rub {
PowerShell и онлайн сервисы. Погода (RP5.ru)
iNNOKENTIY21 11.11.2025
PowerShell функция Get-WeatherRP5rss для получения погоды с сервиса RP5 Примеры вызова Get-WeatherRP5rss с указанием id 5484 — Москва (восток, Измайлово) и переносом строки:. . .
PowerShell и онлайн сервисы. Погода (wttr)
iNNOKENTIY21 11.11.2025
PowerShell Функция для получения погоды с сервиса wttr Примеры вызова: Погода в городе Омск с прогнозом на день, можно изменить прогноз на более дней, для этого надо поменять запрос:. . .
PowerShell и онлайн сервисы. Валюта (ЦБР)
iNNOKENTIY21 11.11.2025
# Получение курса валют function cbr (] $Valutes = @('USD', 'EUR', 'CNY')) { $url = 'https:/ / www. cbr-xml-daily. ru/ daily_json. js' $data = Invoke-RestMethod -Uri $url $esc = 27 . . .
И решил я переделать этот ноут в машину для распределенных вычислений
Programma_Boinc 09.11.2025
И решил я переделать этот ноут в машину для распределенных вычислений Всем привет. А вот мой компьютер, переделанный из ноутбука. Был у меня ноут асус 2011 года. Со временем корпус превратился. . .
Мысли в слух
kumehtar 07.11.2025
Заметил среди людей, что по-настоящему верная дружба бывает между теми, с кем нечего делить.
Новая зверюга
volvo 07.11.2025
Подарок на Хеллоуин, и теперь у нас кроме Tuxedo Cat есть еще и щенок далматинца: Хочу еще Симбу взять, очень нравится. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru