Chủ Nhật, 23 tháng 10, 2011

Backup And Restore SQL Server

Chiến Lược Phục Hồi Dữ Liệu (Data Restoration Strategy)


Có một điều mà chúng ta phải chú ý là hầu như bất kỳ database nào cũng cần được phục hồi vào một lúc nào đó trong suốt chu kỳ sống của nó. Là một người Database Administrator bạn cần phải giảm tối đa số lần phải phục hồi dữ liệu, luôn theo dõi, kiểm tra thường xuyên để phát hiện các trục trặc trước khi nó xảy ra. Phải dự phòng các biến cố có thể xảy ra và bảo đảm rằng có thể nhanh chóng phục hồi dữ liệu trong thời gian sớm nhất có thể được.

Các dạng biến cố hay tai họa có thể xảy ra là:
  • Ðĩa chứa data file hay Transaction Log File hay system file bị mất
  • Server bị hư hỏng
  • Những thảm họa tự nhiên như bão lụt, động đất, hỏa hoạn
  • Toàn bộ server bị đánh cắp hoặc phá hủy
  • Các thiết bị dùng để backup - restore bị đánh cắp hay hư hỏng
  • Những lỗi do vô ý của user như lỡ tay delete toàn bộ table chẳng hạn
  • Những hành vi mang tính phá hoại của nhân viên như cố ý đưa vào những thông tin sai lạc.
  • Bị hack (nếu server có kết nối với internet).Bạn phải tự hỏi khi các vấn đề trên xảy ra thì bạn sẽ làm gì và phải luôn có biện pháp đề phòng cụ thể cho từng trường hợp cụ thể. Ngoài ra bạn phải xác định thời gian tối thiểu cần phục hồi dữ liệu và đưa server trở lại hoạt động bình thường.
Các Loại Backup
Ðể có thể hiểu các kiểu phục hồi dữ liệu khác nhau bạn phải biết qua các loại backup trong SQL Server
  • Full Database Backups : Copy tất cả data files trong một database . Tất cả những user data và database objects như system tables, indexes, user-defined tables đều được backup.
  • Differential Database Backups : Copy những thay đổi trong tất cả data files kể từ lần full backup gần nhất.
  • File or File Group Backups : Copy một data file đơn hay một file group.
  • Differential File or File Group Backups : Tương tự như differential database backup nhưng chỉ copy những thay đổi trong data file đơn hay một file group.Transaction Log Backups : Ghi nhận một cách thứ tự tất cả các transactions chứa trong transaction log file kể từ lần transaction log backup gần nhất. Loại backup này cho phép ta phục hồi dữ liệu trở ngược lại vào một thời điểm nào đó trong quá khứ mà vẫn đảm bảo tính đồng nhất (consistent).
Trong lúc backup SQL Server cũng copy tất cả các hoạt động của database kể cả hoạt động xảy ra trong quá trình backup cho nên ta có thể backup trong khi SQL đang chạy mà không cần phải ngưng lại.
Recovery Models
  • Full Recovery Model : Ðây là model cho phép phục hồi dữ liệu với ít rủi ro nhất. Nếu một database ở trong mode này thì tất cả các hoạt động không chỉ insert, update, delete mà kể cả insert bằng Bulk Insert, hay bcp đều được log vào transaction log file. Khi có sự cố thì ta có thể phục hồi lại dữ liệu ngược trở lại tới một thời điểm trong quá khứ. Khi data file bị hư nếu ta có thể backup được transaction log file thì ta có thể phục hồi database đến thời điểm transaction gần nhất được commited.
  • Bulk-Logged Recovery Model : Ở mode này các hoạt động mang tính hàng loạt như Bulk Insert, bcp, Create Index, WriteText, UpdateText chỉ được log minimum vào transaction log file đủ để cho biết là các hoạt động này có diễn ra mà không log toàn bộ chi tiết như trong Full Recovery Mode. Các hoạt động khác như Insert, Update, Delete vẫn được log đầy đủ để dùng cho việc phục hồi sau này.
  • Simple Recovery Model : Ở mode này thì Transaction Log File được truncate thường xuyên và không cần backup. Với mode này bạn chỉ có thể phục hồi tới thời điểm backup gần nhất mà không thể phục hồi tới một thời điểm trong quá khứ.

Muốn biết database của bạn đang ở mode nào bạn có thể Right-click lên một database nào đó trong SQL Server Enterprise Manager chọn Properties->Options->Recovery



Tuy nhiên có thể tới đây bạn cảm thấy rất khó hiểu về những điều trình bày ở trên. Chúng ta hãy dùng một ví dụ sau để làm rõ vấn đề.


Ví dụ:

Chúng ta có một database được áp dụng chiến lược backup như hình vẽ sau:




Trong ví dụ này ta schedule một Full Database Backup vào ngày Chủ Nhật và Differential Backup vào các ngày thứ Ba và Thứ Năm. Transaction Log Backup được schedule hằng ngày. Vào một ngày Thứ Sáu "đen tối" một sự cố xảy ra đó là đĩa chứa data file của database bị hư và là một DBA bạn được yêu cầu phải phục hồi dữ liệu và đưa database trở lại hoạt động bình thường. Bạn phải làm sao?


Trước hết bạn phải backup ngay Transaction Log File (Trong ví dụ này Transaction Log File được chứa trong một đĩa khác với đĩa chứa Data File nên không bị hư và vẫn còn hoạt động). Người ta còn gọi file backup trong trường hợp này là " the tail of the log" (cái đuôi). Nếu Log File được chứa trên cùng một đĩa với Data file thì bạn có thể sẽ không backup được "cái đuôi" và như vậy bạn phải dùng đến log file backup gần nhất. Khi backup "cái đuôi" này bạn cần phải dùng option NO_TRUNCATE bởi vì thông thường các Transaction Log Backup sẽ truncate(xoá) những phần không cần dùng đến trong transaction log file, đó là những transaction đã được commited và đã được viết vào database (còn gọi là inactive portion of the transaction log) để giảm kích thước của log file. Tuy nhiên khi backup phần đuôi không được truncate để đảm bảo tính consistent (nhất quán) của database.


Kế đến bạn phải restore database từ Full Backup File của ngày Chủ Nhật. Nó sẽ làm 2 chuyện : copy data, log, index... từ đĩa backup vào Data Files và sau đó sẽ lần lượt thực thi các transaction trong transaction log. Lưu ý ta phải dùng option WITH NORECOVERY trong trường hợp này (tức là option thứ 2 "Leave database nonoperational but able to restore additional transaction logs" trong Enterprise Manager). Nghĩa là các transaction chưa hoàn tất (incomplete transaction) sẽ không được roll back. Như vậy database lúc này sẽ ở trong tình trạng inconsistent và không thể dùng được. Nếu ta chọn WITH RECOVERY (hay "Leave database operational. No additional transaction logs can be restored " trong Enterprise Manager) thì các incomplete transaction sẽ được roll back và database ở trạng thái consistent nhưng ta không thể nào restore các transaction log backup được nữa.


Tiếp theo bạn phải restore Differential Backup của ngày Thứ Năm. Sau đó lần lượt restore các Transaction Log Backup kể từ sau lần Differential Backup cuối cùng nghĩa là restore Transaction Log Backup của ngày Thứ Năm và "Cái Ðuôi". Như vậy ta có thể phục hồi data trở về trạng thái trước khi biến cố xảy ra. Quá trình này gọi là Database Recovery.


Cũng xin làm rõ cách dùng từ Database Restoration và Database Recovery trong SQL Server. Hai từ này nếu dịch ra tiếng Việt đều có nghĩa là phục hồi cơ sở dữ liệu nhưng khi đọc sách tiếng Anh phải cẩn thận vì nó có nghĩa hơi khác nhau.


Như trong ví dụ trên Khi ta restore database từ một file backup nghĩa là chỉ đơn giản tái tạo lại database từ những file backup và thực thi lại những transaction đã được commit nhưng database có thể ở trong trạng thái inconsistent và không sử dụng được. Nhưng khi nói đến recover nghĩa là ta không chỉ phục hồi lại data mà còn bảo đảm cho nó ở trạng thái consistent và sử dụng được (usable).

Có thể bạn sẽ hỏi consistent là thế nào? Phần này sẽ được nói rõ trong bài sau về Data Integrity. Nhưng cũng xin dùng một ví dụ đơn giản để giải thích. Trong ví dụ về thế nào là một transaction ở bài 3 : Giả sử số tiền $500 được trừ khỏi account A nhưng lại không được cộng vào account B và nếu database không được quá trình khôi phục dữ liệu tự động (automatic recovery process) của SQL rollback thì nó sẽ ở trạng thái inconsistent. Nếu database ở trạng thái giống như trước khi trừ tiền hoặc sau khi đã cộng $500 thành công vào account B thì gọi là consistent.

Cho nên việc backup Transaction Log File sẽ giúp cho việc recovery data tới bất kỳ thời điểm nào trong quá khứ. Ðối với Simple Recovery Model ta chỉ có thể recover tới lần backup gần nhất mà thôi.

Như vậy khi restore database ta có thể chọn option WITH RECOVERY để roll back các transaction chưa được commited và database có thể hoạt động bình thường nhưng ta không thể restore thêm backup file nào nữa, thường option này được chọn khi restore file backup cuối cùng trong chuỗi backup. Nếu chọn option WITH NORECOVERY các transaction chưa được commited sẽ không được roll back do đó SQL Server sẽ không cho phép ta sử dụng database nhưng ta có thể tiếp tục restore các file backup kế tiếp, thường option này được chọn khi sau đó ta còn phải restore các file backup khác.

Không lẽ chỉ có thể chọn một trong hai option trên mà thôi hay sao? Không hoàn toàn như vậy ta có thể chọn một option trung lập hơn là option WITH STANDBY (tức là option 3 "Leave database read-only and able to restore additional transaction logs" trong Enterprise Manager). Với option này ta sẽ có luôn đặc tính của hai option trên : các incomplete transaction sẽ được roll back để đảm bảo database consistent và có thể sử dụng được nhưng chỉ dưới dạng Read-only mà thôi, đồng thời sau đó ta có thể tiếp tục restore các file backup còn lại (SQL Server sẽ log các transaction được roll back trong undo log file và khi ta restore backup file kế tiếp SQL Server sẽ trả lại trạng thái no recovery từ những gì ghi trên undo file). Người ta dùng option này khi muốn restore database trở lại một thời điểm nào đó (a point in time) nhưng không rõ là đó có phải là thời điểm mà họ muốn không, cho nên họ sẽ restore từng backup file ở dạng Standby và kiểm chứng một số data xem đó có phải là thời điểm mà họ muốn restore hay không (chẳng hạn như trước khi bị delete hay trước khi một transaction nào đó được thực thi) trước khi chuyển sang Recovery option.
Backup Database
Trong phần này chúng ta sẽ bàn về cách backup database. Nhưng trước hết chúng ta hãy làm quen với một số thuật ngữ dùng trong quá trình backup và restore. Có những từ ta sẽ để nguyên tiếng Anh mà không dịch.
Thuật Ngữ
Giải Thích
Backup
Quá trình copy toàn bộ hay một phần của database, transaction log, file hay file group
 hình thành một backup set. Backup set được chứa trên backup media (tape or disk)
 bằng cách sử dụng một backup device (tape drive name hay physical filename)
Backup Device
Một file vật lý (như C:\SQLBackups\Full.bak) hay tape drive cụ thể (như \\.\Tape0)
 dùng để record một backup vào một  backup media.
Backup File
File chứa một backup set
Backup Media
Disk hay tape được sử dụng để chứa một backup set. Backup media có thể chứa
 nhiều backup sets (ví dụ như từ nhiều SQL Server 2000 backups và từ nhiều Windows 2000 backups).
Backup Set
Một bộ backup từ một lần backup đơn được chứa trên backup media.


Chúng ta có thể tạo một backup device cố định (permanent) hay tạo ra một backup file mới cho mỗi lần backup. Thông thường chúng ta sẽ tạo một backup device cố định để có thể dùng đi dùng lại đặc biệt cho việc tự động hóa công việc backup. Ðể tạo một backup device dùng Enterprise Manager bạn chọn Management->Backup rồi Right-click->New

Backup Device. Ngoài ra bạn có thể dùng sp_addumpdevice system stored procedure như ví dụ sau:



USE Master Go Sp_addumpdevice 'disk' ,
 'FullBackupDevice' ,
 'E:\SQLBackups\Full.bak'



Ðể backup database bạn có thể dùng Backup Wizard hoặc click lên trên database muốn backup sau đó Right-click->All Tasks->Backup Database... sẽ hiện ra window như hình vẽ sau:


Sau đó dựa tùy theo yêu cầu của database mà chọn các option thích hợp. Ta có thể schedule cho SQL Server backup định kỳ.


Restore Database

Trước khi restore database ta phải xác định được thứ tự file cần restore. Các thông tin này được SQL Server chứa trong msdbdatabase và sẽ cho ta biết backup device nào, ai backup vào thời điểm nào. Sau đó ta tiến hành restore. Ðể restore bạn Right-click->All Tasks->Restore database... sẽ thấy window như hình vẽ sau:


Nếu bạn restore từ một instance khác của SQL Server hay từ một server khác bạn có chọn From device option và chọn backup device (file backup) tương ứng .

Lưu ý nếu bạn muốn overwrite database có sẵn với data được backup bạn có thể chọn option Force restore over existing database như hình vẽ sau:




Bạn có thể chọn leave database operational hay nonoperational tùy theo trường hợp như đã giải thích ở trên.
Tóm lại trong bài này chúng ta đã tìm hiểu một chút lý thuyết về backup và restore database trong SQL Server. Ðể có thể hiểu rõ hơn bạn cần phải thực tập hay làm thử để có thêm kinh nghiệm. Trong bài sau chúng ta sẽ bàn về đề tài Data Integrity nghĩa là làm sao để đảm bảo data chứa trong database là đáng tin cậy và không bị "lũng lỗ" như cách nói bình dân mà tôi thường hay dùng.

Thứ Bảy, 22 tháng 10, 2011

Kiếm tiền với RanthemPTC.Com nhanh chóng và hiệu quả

Lời đầu tiên mình muốn chào tất cả anh em trên site DBS. Hiện nay mình cũng thu được kha khá tiền từ làm việc Online tại nhà nên mình muốn chia sẽ với các bạn

RANTHEMPTC (khai sinh ngày 15/6/2011)

Giá click: 0.001$
Thanh toán qua : Alertpay/Paypal/Leberty Reserve/Okpay
Số quảng cáo mỗi ngày: 7+ ads
Tối thiểu thanh toán: 0.02$ (Click 3 ngày là có thể rút tiền)
Thời gian thanh toán: Instant (Ngay lập tức)Trả tự động nên rất yên tâm
Không tính phí trả nữa nhé.
Hiện nay đã trả trên 9000 lần cho thành viên.

*Điều kiện đặc biệt là chỉ Email của Gmail đăng kí mới nhận được kí hoạt nên các bạn phải dùng mail của Gmail nhé*

Có trên 5000 thành viên hiện tại (cập nhật ngày 21/10/2011)
Đăng kí tại đây...
Các bạn nào làm khoảng 2 hoặc 3 ngày làm có thể rút được rồi.

Nếu bạn nào muốn mình có thể trả lại ref (chú ý đây là bí mật của mình và các bạn từ ref vui lòng ko chia sẽ vì qui định 1 số trang ko cho bonus nhé) mình sẽ tính phí chuyển như PP thôi mình sẽ ko ăn gia 1 cắt nào cả.

đây là proof cho anh em xem nhé:




Cảm ơn các bạn đã dành thời gian đọc.

Chúc các bạn sẽ thu được nhiều tiền từ site này!

Bài viết liên quan:

Thứ Tư, 19 tháng 10, 2011

8 điều "Ăn trộm" cũng nên biết


Đức Phật nói : Có 8 việc mà một tên trộm không nên phạm vào. Phạm vào thì mau chóng đi đến đường cùng. 8 việc đó là :


1/ Đánh người không nên đánh: Nghĩa là lỡ làm ăn trộm thì… ăn trộm thôi. Đừng có đánh người ta huống là giết người. Giết người nữa thì thành ăn cướp rồi. Ăn trộm của người ta là đã quá lắm rồi, đừng đánh, đừng giết ….

2/ Lấy trộm không để lại thứ gì: Có lấy đồ thì đừng lấy hết, nhớ chừa lại chút gì đó cho người ta. Nghĩa là, dù là ăn trộm thì cũng phải chừa … cái hậu để còn bớt tội.

3/ Giết nữ nhân: Đối với người yếu đuối hơn mình nên cần giúp đỡ như làm điều trái ngược lại đó là một tội lớn.

4/ Hiếp dâm phụ nữ: Hành động được xã hội câm ghét liệu phát hiện ra bạn dám đứng trước mặt người thân

5/ Xâm phạm người xuất gia: Người xuất gia đã không màn đến tiền, tài, danh vọng tại sao ta phải hại họ.

6/ Xâm phạm ngân khố của nhà nước: Điều mà ai cũng biết quốc khố là tài sản chung của quốc gia nuôi sống dân tộc phạm vào là một tội lớn.

7/ Làm việc quá gần nhà: Ai cũng biết rằng hành nghề gần nhà thì trước sau cũng bị lùng ra

8/ Không khéo cất giấu đồ đạc: Hậu quả thì ai cũng biết và luật pháp sẽ không khoang dung nhất là những đồ vẫn có giá trị hoặc to lớn




Không phạm vào những việc đó thì hy vọng việc ăn trộm của mình không dẫn đến cái quả đau thương. Tuy vậy có những điều cũng cần phải biết:. Đi đêm có ngày gặp ma. Ăn trộm hoài cũng có ngày sa lưới tù tội.. Ăn trộm cũng có nghiệp của nó. Hễ kiếp này ăn trộm thì kiếp sau không chừng sẽ làm ăn trộm tiếp. Bởi quả báo của nghề ăn trộm là sinh vào nhà nghèo khó, bản thân cũng sẽ nghèo khó. Mà nghèo khó ... thì dễ sinh trộm cướp..Ăn trộm cũng thành thói quen. Quen lấy của hiên hạ làm của mình rồi thì nó cũng thành cái tật, hễ cứ thấy là muốn lượm, dù không đói không thiếu ...
Hy vọng sẽ không có một tên Luyện thứ 2...

Blog on TamTay.VN
Edit by DINHBAS

10 cách xả stress hiệu quả cao


Cuộc sống không thể tránh được những căng thẳng nhưng quan trọng là bạn biết cách loại bỏ nó hay không. Đôi khi chỉ cần vài phút cũng có thể làm nên những điều khác biệt.

Đặc biệt giới trẻ hiện nay phát triển quá sớm nên về tinh thần không đủ khả năng chịu áp tải về stress công việc nên dinhbas quyết định chia sẽ 10 phương pháp xả stress cho các bạn sử dụng vào lúc stress tăng cao.

Dưới đây là 10 cách xả stress khá hiệu quả mà bạn nên tham khảo:




1. Đừng tự làm khổ mình

Có thể bạn có tài, bạn không ngại khó nhưng nếu công việc đang chồng chất như núi thì cũng không phải là quá đáng nếu bạn từ chối một lời đề nghị làm thêm việc này việc kia từ sếp. Không nhất thiết phải làm mọi việc mà mọi người yêu cầu. Hãy nói không khi cần để công việc bạn làm đạt hiệu quả không chỉ về số lượng mà còn cần cả chất lượng.

Quá ôm đồm hay nể nang mà việc gì bạn cũng “ngó” một tí rồi chẳng hoàn thành việc nào còn đem lại nhiều áp lực hơn. Đôi khi làm hỏng việc thì bạn còn đáng trách hơn là từ chối khi vượt quá khả năng. Con người cũng chỉ có giới hạn của nó và hãy luôn giữ cho mình được niềm yêu thích công việc nhé.



2. Làm việc có khoa học

Nếu biết cách làm việc khoa học, bạn đã loại bỏ được yếu tố stress trong công việc rất nhiều rồi đấy. Làm việc khoa học diễn ra dưới nhiều hình thức như bàn làm việc có được sắp xếp gọn gàng hay không, lịch trình làm việc, sổ nhật ký, những ghi chú cần làm để tránh quên, mất tài liệu hoặc ngay cả việc bừa bộn cũng đem đến sự khó chịu cho bạn. Sắp xếp công việc khoa học giúp bạn giảm tải gánh nặng cho công việc rất nhiều.


3. Đứng lên và vươn vai

Điều này khá đơn giản, nhanh chóng mà đem lại hiệu quả cao. Chỉ cần bạn đứng lên, để tay lên trên đâu hít thở sâu hoặc vươn vai, cố gắng duỗi cả chân và ngón chân nữa nhé. Nếu trong điệu kiện có thể, bạn có thể nhảy lò cò như một cách chơi ô chữ ngày bé sẽ giúp các cơ được duỗi ra và cũng là một cách tuyệt vời để đốt cháy calo trong ngày.


4. Giúp ai đó

Bạn quá mệt mỏi và chỉ muốn ai đó giúp mình? Thay vì chờ đợi ai đó tại sao bạn không đứng lên và giúp đỡ người khác nhỉ. Có thể chỉ là những điều nhỏ nhặt như giúp đồng nghiệp tìm bút bị rơi hay bê hộ một khay nước. Không gian xung quanh bạn sẽ thay đổi hẳn, nụ cười vui vẻ của đồng nghiệp có được coi là đang giúp bạn có một không khí và tâm trạng tốt hơn không? Nhớ rằng: Không có sự giúp đỡ nào là quá thiệt thòi đâu.


5. Ra khỏi ghế ngồi làm việc

Chỉ cần đứng dậy và đi lại cũng là một cách loại trừ căng thẳng trong công việc. Điều này không chỉ giúp bạn giảm stress và mệt mỏi với máy tính hay hoa mắt với những con số trên giấy tờ mà còn giúp cơ thể vận động tránh được tình trạng mỏi cổ, đau lưng, nhức mắt vì ngồi lâu. Bạn có thể đi ra nhà vệ sinh hoặc ra máy bán hàng tự động để mua cốc nước. Thật dễ để thực hiện phải không?



6. Xem một video hài

Nếu tại nơi làm việc có sử dụng internet, bạn có thể truy cập vào trang youtube v.v..., tìm kiếm một clip hài nào đó để thư giãn và xả stress. Chỉ cần vài phút tự cho phép mình nghỉ ngơi sau đó quay trở lại công việc, cảm giác mệt mỏi cũng bớt đi được phần nào đấy. Đừng để bận rộn quá khiến bạn quên đi điều này nhé.


7. Ăn một thứ gì đấy bạn thích

Nếu căng thẳng quá, bạn có thể bù đắp cho cái dạ dày một thứ quà vặt yêu thích. Khi sở thích được thoả mãn nghĩa là bạn cũng giảm bớt được một gánh nặng rồi. Để tốt cho tâm trạng bạn cũng có thể nhấm nháp một miếng socola nho nhỏ chẳng hạn.


8. Cởi giày của bạn ra

Bạn không nghĩ cách này sẽ giảm stress ư? Nhưng thật tuyệt vời là nó có thể đem lại cảm giác dễ chịu cho mình. Không bị gò bó nóng bức trong chiếc giày và tốt hơn nữa nếu có quả bóng massage chân hoặc quả bóng tennis để bạn lăn lăn đôi bàn chân của mình trong lúc làm việc. Bạn cứ thử đi, đây là một cách khiến bạn sẽ cảm thấy thoái mái hơn nhiều đấy.


9. Có ai đó trêu cười bạn

Thật vui nếu bạn nhận được lời trêu đùa từ ai đó như: “Đố cậu biết cái gì có bốn chân mà không thể chạy được?” Dễ quá phải không, bạn có thẩm nghĩ đố thế cũng đòi đố “Cái bàn chứ cái gì nữa”. Những câu đùa vui nhỏ nhỏ sẽ giúp bạn thấy được ngoài những khó khăn của công việc vẫn còn nhiều điều hạnh phúc khác. Quan trọng là bạn biết ai sẽ là người đem lại cho mình những tiếng cười? Có thể là những người bạn thân hoặc chính đồng nghiệp ngay bên mình. Nhớ là luôn cởi mở và vui vẻ, luôn đem tiếng cười và sự thoải mái với những người bên cạnh, họ cũng sẽ làm vậy để giúp bạn vượt qua cơn stress chính mình.


10. Hít thở thật sâu

Bạn sẽ ngạc nhiên bởi những cảm nhận tốt hơn sau khi hít thật sâu và thở ra từ từ đấy. Ít ra bạn có thể thấy lồng ngực mình tràn đầy sinh khí và mỉm cười tự hỏi tại sao lại làm vậy. Thật hài hước, trong phút chốc bạn có thể quên đi những khó chịu vừa xảy ra. Giờ với cái đầu bình tĩnh hơn, bạn sẽ sáng suốt tìm ra được giải pháp cho công việc của mình.



DINHBAS Blog

Theo AWT

Hình Avatar đẹp cho các nàng

3.gif6.gif


5.gif8.gif


1.gif7.gif


2.gif4.gif


11.gif37.gif


13.gif16.gif


15.gif10.gif



12.gif19.gif



23.gif22.gif



22.gif25.gif



17.gif24.gif



18.gif20.gif



29.gif32.gif


31.gif35.gif



26.gif34.gif



28.gif30.gif



39.gif36.gif



DBS M05479
Quang Cao