Scrip - Xử lý sự cố lỗi

Chia sẻ: Lac Tran | Ngày: | Loại File: PDF | Số trang:7

0
104
lượt xem
11
download

Scrip - Xử lý sự cố lỗi

Mô tả tài liệu
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

Optio Explicit on Dim o objWMIServic ce Dim o objNetAdapter r Dim s strComputer Dim s strAddress Dim arrIPA Address Dim arrSub bnetMask Dim colNe etAdapters Dim errEn nableStatic If WScript t.Arguments.Co ount = 0 Then Wscript t.Echo "Usage: ChangeIPAdd dress.vbs new_ _IP_address" WScrip pt.Quit End If strComputer = "xp2" strAddress = Wscript.Arg s guments.Item(0 0) arrIPAddre = Array(str ess rAddress) arrSubnetM Mask = Array(" "255.255.255.0 0") Set objWM MIService = Ge etObject("winm mgmts:\\" & str rComputer & " "\root\cimv2") Set colNetA Adapters = obj jWMIService.E ExecQuery("Select...

Chủ đề:
Lưu

Nội dung Text: Scrip - Xử lý sự cố lỗi

  1. Qu lý các mạng W uản c Windows d dùng scrip - Phần 7: Xử lý sự cố lỗi pt i Tron bài viết tr ng rước chúng t đã dùng đ kịch bản ta đến ChanngeIPAddres ss.vbs được phát triển trư đó và đã sử ước ã dụng nó để thay đổi địa chỉ I trên máy t g IP tính từ xa. Đ Đây là nh hững gì mà c chúng ta đã tthay đổi kịch bản: h Optio Explicit on Dim o objWMIServicce Dim o objNetAdapter r Dim s strComputer Dim s strAddress Dim arrIPA Address Dim arrSubbnetMask Dim colNeetAdapters Dim errEn nableStatic If WScript t.Arguments.Coount = 0 Then Wscriptt.Echo "Usage: ChangeIPAdd dress.vbs new_ _IP_address" WScrippt.Quit End If strComputer = "xp2" strAddress = Wscript.Arg s guments.Item(00) arrIPAddre = Array(str ess rAddress) arrSubnetM Mask = Array(" "255.255.255.0 0") Set objWMMIService = Ge etObject("winmmgmts:\\" & str rComputer & " "\root\cimv2") Set colNetA Adapters = obj jWMIService.EExecQuery("Select * from WWin32_Network kAdapterConfi iguration where IPEnabled==TRUE") For Each o objNetAdapter in colNetAdap pters errEnab bleStatic = objN NetAdapter.EnnableStatic(arrI IPAddress, arrS SubnetMask) Next Dòng: strComputer = "xp2" cho chún ta biết rằn máy tính đ ng ng được tích hợ bởi kịch b có tên XP Máy tính điều khiển xa ợp bản P2. h n XP2 ban đầu có địa chỉ IP là 172 c 2.16.11.43. Bây giờ k chúng ta chạy kịch b này bằng cách đánh ChangeIPA khi a bản g Address.vbs 172.16.11.6 từ 65 một máy trạm quản lý có tên là X những th xảy ra đư đưa ra dư đây: l XP, hứ ược ưới 1. Kịch b đã hoạt động. Ví dụ địa chỉ của X đã thay đổi từ 172.1 bản đ XP2 16.11.43 thà 172.16.11.65. ành 2. Kịch b cần đến nhiều thời gi để thực t bản n ian thi 3. Kịch b trả lại lỗi dưới đây: C bản i C:\tools\Cha angeIPAddre ess.vbs(23, 6 SWbemOb 6) bjectEx: The remote procedure ca failed. all
  2. Làm thế nào chúng ta có thể giải quyết được các kết quả đó? Giải pháp dễ dàng Một thứ chúng ta có thể thực hiện là nói rằng “Hãy bỏ qua lỗi”. Đó là những gì được nói với phương pháp này. Sau tất cả, bất kỳ quản trị viên trong thế giới thực nào cũng biết rằng CNTT không phải là một khoa học đúng về mọi chi tiết và chúng thường kết thúc bằng việc áp dụng “cách giải quyết khác” đối với các vấn đề nảy sinh khi không có những giải pháp đúng cho chúng. Vì vậy làm thế nào chúng ta có thể bỏ qua lỗi? Hãy thêm dòng dưới đây vào gần vị trí bắt đầu của phần đầu (header): On Error Resume Next Hay nói cách khác, phần đầu (header) của chúng ta sẽ như sau: Option Explicit On Error Resume Next Dim objWMIService ... Bây giờ chúng ta không xem lỗi, và kịch bản của chúng ta làm việc. Tuy nhiên nó vẫn cần đến nhiều thời gian để thực thi, thực tế có thể cần đến vài phút. Vậy cái gì sẽ tiếp diễn? Xử lý sự cố thông báo lỗi Các thông báo lỗi đôi khi khá khó hiểu và điều này là một trong những vấn đề đáng quan tâm. Đây là một thông báo lỗi: SWbemObjectEx: The remote procedure call failed. Và đây là dòng mã tạo ra nó: errEnableStatic = objNetAdapter.EnableStatic(arrIPAddress, arrSubnetMask) Dòng mã này làm việc (ví dụ địa chỉ IP bị thay đổi trên máy tính mục tiêu) nhưng sau đó nó đưa ra một thông báo lỗi. Tại sao lại như vậy? Chúng ta hãy bắt đầu bằng cách tìm hiểu SwebObjectEx có ý nghĩa gì. Tìm kiếm nhanh trong MSDN có thể cho thấy (http://msdn2.microsoft.com/en-us/library/aa393259.aspx): Extends the functionality of SWbemObject. This object adds the Refresh method for SWbemRefresher objects. (Mở rộng chức năng của SWbemObject. Đối tượng này bổ sung phương pháp Refresh cho các đối tượng SwbemRefresher)
  3. Vì vậy SwbemObjectEx cơ bản chỉ bổ sung thêm chức năng cho SWbemObject. Vậy SwbemObject là gì? Contains and manipulates a single WMI object class or instance. (Gồm một đối tượng WMI hoặc một sự kiện) Điều đó có nghĩa gì? Trang này cho chúng ta nhiều thông tin nhưng nó không thích hợp. Mặc dù vậy trong các trường hợp, SwbemObject (SWbemObjectEx) là tất cả những gì bạn quản lý hay truy vấn trong WMI. Trong kịch bản của chúng ta, chúng ta đang truy vấn lớp Win32_NetworkAdapterConfiguration và trả về một bộ sưu tập các đối tượng gọi là colNetAdapter thể hiện các adapter mạng trên máy tính. Vì vậy SWbemObjectEx (hoặc SWbemObject) đã đề cập đến trong thông báo lỗi này làm đơn giản hóa đối tượng đang thể hiện bản thân adapter mạng, ví dụ như objNetAdapter. Vậy tại sao objNetAdapter tạo ra lỗi. Dẫu sao đây cũng dường như trở thành vấn đề. Theo một trong những chuyên gia có uy tín, có thể một thành phần nào đó có trong hotfix cho Windows XP bị thay đổi cách mà lệnh gọi trả về được tạo và được đệ trình khi câu lệnh gây ra lỗi được thực thi. Thông thường nếu gọi phương pháp EnableStatic của một đối tượng được thuyết minh bằng một ví dụ của lớp Win32_NetworkAdapterConfiguration hoàn toàn thành công nó sẽ trả về 0, có nghĩa là không có lỗi. Còn nếu nó trả về 1 thì điều đó có nghĩa cần phải khởi động lại. Rõ ràng với Windows XP sẽ không cần phải khởi động lại khi bạn thay đổi địa chỉ IP trên adapter mạng. Nếu với một vài lý do, một hotfix có thể thay đổi gì đó trong WMI hoặc thành phần khác để Windows không khởi động lại trước khi địa chỉ mới được thay thế trên máy mục tiêu, điều này có thể tạo ra một lỗi vì cấu hình adapter mạng trên máy rơi vào trạng thái không rõ ràng cho tới khi máy tính này được khởi động lại. Tuy nhiên khi kịch bản vẫn đang chạy trên máy trạm quản trị, khi cấu hình adapter mạng của máy tính mục tiêu đang ở trạng thái không xác rõ ràng thì kết nối RPC giữa hai máy tính là rất tồi trước khi kịch bản này kết thúc. Chính vì vậy sẽ xuất hiện lỗi ở đây. Chí ít đó cũng là câu trả lời tốt nhất mà chúng tôi có được cho vấn đề này, và chúng tôi vẫn tiếp tục nghiên cứu tỉ mỉ. Tuy nhiên hãy xem nếu chúng ta có thể xác nhận vì một lý do nào đó mà vấn đề này được giải quyết, ví dụ lỗi đó chỉ liên quan với phương pháp EnableStatic của Win32_NetworkAdapterConfiguration. Việc gì sẽ xảy ra nếu chúng ta cố gắng viết một kịch bản khác để thực hiện một việc gì đó khác với adapter mạng trên máy tính mục tiêu thay vì thay đổi địa chỉ IP của nó? Ví dụ, làm cách nào để thay đổi được cổng mặc định thay vì địa chỉ IP trên máy tính mục tiêu? Nếu điều đó được thực hiện thì ít nhất chúng ta cũng có thể kết nối thành công từ máy trạm quản trị đến máy tính từ xa và gọi phương pháp WMI để thay đổi thiết lập mạng trên nó. Thay đổi cổng mặc định Ở phần này chung tôi khuyên bạn nên quay lại đọc một chút phần 4 của loạt bài này, ở đó chúng tôi đã giới thiệu cho bạn cách sử dụng MSDN để học cách sử dụng các thuộc tính và phương pháp của Win32_NetworkAdapterConfiguration. Chúng tôi cho rằng bằng cách làm như vậy bạn có thể tự viết một kịch bản như vậy. Hãy thử nó! TẠM NGƯNG
  4. Khi bạn đã cố gắng viết kịch bản cho riêng mình, đôi khi nó có thể làm việc, đôi khi không làm việc. Nếu nó không làm việc, hãy thực hiện các bước dưới đây: 1. Đầu tiên vào trang MSDN của Win32_NetworkAdapterConfiguration class. 2. Tìm trên trang này phương pháp phải thực hiện để thay đổi cổng trên adapter mạng. Kiểm tra nhanh trong trang sẽ cho bạn điều này: SetGateways - Specifies a list of gateways for routing packets destined for a different subnet than the one this adapter is connected to. (SetGateways – một danh sách cổng dành cho việc định tuyến các gói đã được trù định trước đối với subnet khác so với subnet mà adapter này được kết nối đến) Đó chính là những gì chúng ta muốn, vì vậy kích chuột vào SetGateways để mở trang SetGateways Method của Win32_NetworkAdapterConfiguration Class 3. Trên trang SetGateways Method này bạn sẽ thấy giải thích này: The SetGateways WMI class method specifies a list of gateways for routing packets to a subnet that is different from the subnet that the network adapter is connected to. This method only works when the Network Interface Card (NIC) is in the static IP mode. (Phương pháp lớp SetGateways WMI chỉ định một danh sách cổng dành cho việc định tuyến các gói cho một mạng con khác đối với mạng con mà adapter mạng được kết nối đến. Phương pháp này chỉ làm việc khi Network Interface Card (NIC) ở chế độ IP tĩnh) Chính vì vậy bạn đã học được rằng máy tính mục tiêu phải có địa chỉ tĩnh trước khi bạn gọi phương pháp này. Đọc kỹ hơn bạn có thể tìm thấy cú pháp cho việc gọi phương pháp này như dưới đây: SetGateways(A,B) Ở đây A là biến chuỗi gồm địa chỉ IP cho cổng, B là một giá trị nguyên từ 1 đến 9999 chỉ định tham số đó. Bây giờ bạn phải có đủ thông tin để viết kịch bản. Cách đơn giản nhất là bắt đầu với kịch bản ChangeIPAddress.vbs gốc của chúng ta có trong phần 2 và thay đổi nó một chút cho tới khi chúng ta có được một kịch bản mới như dưới đây: '========================= ' NAME: ChangeGateway.vbs ' 'AUTHOR: Mitch Tulloch 'DATE: February 2007 ' 'ARGUMENTS: '1. gateway_address '2. metric '=========================-
  5. Option Explicit Dim objWMIService Dim objNetAdapter Dim strComputer Dim strGateway Dim arrGateway Dim intMetric Dim arrMetric Dim colNetAdapters Dim errGateway 'Check for missing arguments If WScript.Arguments.Count = 0 Then Wscript.Echo "Usage: ChangeGateway.vbs gateway_address metric" WScript.Quit End If strComputer = "xp2" strGateway = Wscript.Arguments.Item(0) arrGateway = Array(strGateway) intMetric = Wscript.Arguments.Item(1) arrMetric = Array(intMetric) Set objWMIService = GetObject("winmgmts:\\" & strComputer & "\root\cimv2") Set colNetAdapters = objWMIService.ExecQuery("Select * from Win32_NetworkAdapterConfiguration where IPEnabled=TRUE") For Each objNetAdapter in colNetAdapters errGateway = objNetAdapter.SetGateways(arrGateway, arrMetric) Next 'Display result or error code If errGateway=0 Then Wscript.Echo "Adapter's gateway has been successfully changed to " & strGateway Else Wscript.Echo "Changing the adapter's gateway was not successful. Error code " & errGateway End If Copy đoạn kịch bản này vào Notepad (trong chế độ Word Wrap đã bị bỏ) và lưu lại với tên ChangeGateway.vbs. Giờ hãy kiểm tra nó. Truy cập vào máy từ xa XP2, mở cửa sổ lệnh nhập vào lệnh ipconfig /all và kết quả như sau: C:\>ipconfig /all Windows IP Configuration Host Name . . . . . . . . . . . . : XP2 Primary Dns Suffix . . . . . . . : contoso.com Node Type . . . . . . . . . . . . : Unknown IP Routing Enabled. . . . . . . . : No WINS Proxy Enabled. . . . . . . . : No
  6. Ethernet adapter Local Area Connection: Connection-specific DNS Suffix . : Description . . . . . . . . . . . : Intel 21140-Based PCI Fast Ethernet Adapter (Generic) Physical Address. . . . . . . . . : 00-03-FF-21-88-8C Dhcp Enabled. . . . . . . . . . . : No IP Address. . . . . . . . . . . . : 172.16.11.80 Subnet Mask . . . . . . . . . . . : 255.255.255.0 Default Gateway . . . . . . . . . : 172.16.11.1 C:\> Bây giờ trên máy trạm quản trị XP, bạn mở cửa sổ lệnh và chạy kịch bản mới này như dưới đây: C:\tools>ChangeGateway.vbs 172.16.11.2 5 Microsoft (R) Windows Script Host Version 5.6 Copyright (C) Microsoft Corporation 1996-2001. All rights reserved. Adapter's gateway has been successfully changed to 172.16.11.2 C:\tools> Kịch bản này cần đến khoảng 5 giây để kết thúc, không có lỗi nào xuất hiện (Lưu ý rằng ở đây chúng tôi đã bỏ qua On Error Resume Next từ header của kịch bản đã đưa ra vì chúng tôi muốn quan sát bất kỳ lỗi nào nếu chúng xuất hiện) Hãy quay trở lại máy tính từ xa XP2 và chạy ipconfig /all một lần nữa: C:\>ipconfig /all Windows IP Configuration Host Name . . . . . . . . . . . . : XP2 Primary Dns Suffix . . . . . . . : contoso.com Node Type . . . . . . . . . . . . : Unknown IP Routing Enabled. . . . . . . . : No WINS Proxy Enabled. . . . . . . . : No Ethernet adapter Local Area Connection: Connection-specific DNS Suffix . : Description . . . . . . . . . . . : Intel 21140-Based PCI Fast Ethernet Adapter (Generic) Physical Address. . . . . . . . . : 00-03-FF-21-88-8C Dhcp Enabled. . . . . . . . . . . : No IP Address. . . . . . . . . . . . : 172.16.11.80 Subnet Mask . . . . . . . . . . . : 255.255.255.0 Default Gateway . . . . . . . . . : 172.16.11.2 C:\>
  7. Nó đã làm việc. Không có lỗi nào xuất hiện – chúng ta đã chạy một kịch bản từ xa đối với một máy tính khác và nó đã thay đổi cổng mặc định của máy tính mục tiêu. Chúng ta có thể kiểm tra xem tham số đo có bị thay đổi hay không? Lệnh ipconfig không hiển thị thông tin này nhưng chúng ta có thể sử dụng netsh để có được điều này như dưới đây: C:\>netsh interface ip show address Configuration for interface "Local Area Connection" DHCP enabled: No IP Address: 172.16.11.80 SubnetMask: 255.255.255.0 Default Gateway: 172.16.11.2 GatewayMetric: 5 InterfaceMetric: 0 C:\> Đây chính là kết quả cần thấy!  
Đồng bộ tài khoản