Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

Ip sperre bei Bewertungsfunktion

Frage Entwicklung PHP

Mitglied: ThermoTubbie

ThermoTubbie (Level 1) - Jetzt verbinden

05.09.2006, aktualisiert 07.09.2006, 3835 Aufrufe, 4 Kommentare

Suche schnelle Möglichkeit zum überprüfen der Bewertung

Hallo ich brauch mal wieder Hilfe ;),
ich habe auf meiner Seite eine Bewertungsfunktion für Links. Nun bin ich dabei eine IP Sperre mit Hilfe einer DB zuentwicklen. Das Problem dabei ist, dass ich schon lange Zeit am Grübbeln bin wie die aufgebaut sein muss um schnell zu arbeiten.

Da ich so was noch nie gebastelt habe, würde ich mich über Kommentare/Punkte an denen ich was übersehen habe / verbesserungen / ... freuen ;)


Hab zwei Plannungen

Meine 1te sieht so aus:

DB: Tabelle mit den Spalten ID, IP, Link ID, Datum

Ablauf:
1. Wenn etwas bewertet wird, wird zuerst ein delete Statement ausgeführt welches alle Datensätze löscht die älter als 1Tag sind. => keine veraltete Datensätze mehr

2. Anschließend ein weiteres Statement welches guckt ob der Benutzer schon eine Bewertung für diesen Link abgegeben hat. Wird ein Datensatz gefunden
=> "hast schon bewertet".

3. Wird keiner gefunden wird ein neuer Datensatz mit der IP des Benutzers, Link ID, aktuelle Datum in die DB gespeichern. => Sperre für einen Tag steht.


Nur irgendwie sind mir das viel zuviele Zugriffe auf die DB Da ich die Bewertungsfunktion mit AJAX gebastelt habe, habe ich "Angst" das mir diese Zugriffe die Ladezeiten so stark erhöhen, dass der Geschwindigkeitsvorteil von AJAX flöten geht...



Daher habe ich auch noch eine zweite, nur die ist aufwändiger zu Programmieren

DB: Tabelle mit den Spalten ID, IP, Link ID, Datum

1. Beim klick auf die Wertung werden alle Datensätze in ein Array geladen.

2. Im Array werden dann die Datensätze überprüft und die "makiert", welche über 1 Tag alt sind.

3. Es wird überprüft ob der Benutzer schon den Link bewertet hat (Vergleich mit Datensätzen aus dem Array)
Wenn der Benutzer schon bewertet hat wird eine variable auf false gesetzt/ bzw true wenn noch nicht bewertet (oders so)

4. Dann wird ein langer String erstellt, in der aus der ein delete Statement erhält welches die markierten Datensätze löscht, sowie ein neuen Datensatz mit IP, Datum, usw, wenn der Benutzer noch nicht bewertet hat.

5. Der SQL Befehl String aus Punkt 4 wird an die DB abgefeuert. Dann noch meldung, "bla bla hast schon bewertet" / "bla bla Bewertung in DB"


Hoffe ich hab mich halbwegs kla ausgedrückt^^


Wie seht ihr das? Soll ich einer der Lösungen programmiern ? Hat jemand eine schnellere Lösung? Alles her, was euch dazu einfällt ;)

Mit freundlichen Grüßen
Martin /ThermoTubbie
Mitglied: DaSam
05.09.2006 um 20:10 Uhr
Hi,

die DB sollte Dir doch die meiste Arbeit abnehmen - da sollte es doch nicht vorrangig um die Implementierung gehen. Die DB-Elemente sind ja fast schon so trivial, dass auch AJAX damit keine Probleme haben sollte .

Was ich nur machen würde: Je nach verwendeter SQL Variante und sonstigem Umfeld würde ich beispielsweise jede Stunde per cron oder DB-Wartung die Einträge, welche älter als 1 Tag sind rauslöschen - ob die jetzt 1 Tag und 59 Minuten als sind, dürfte wohl kaum eine Rolle spielen. Spart Dir aber jede Menge Aufwand beim "Klicken" ...

Und vergiss nicht, schön brav Indexe zu erstellen, damit die DB auch performant ist. Ansonsten sollte eine kluge DB schon sehr performant sein.

cu,
Alex
Bitte warten ..
Mitglied: ThermoTubbie
05.09.2006 um 23:04 Uhr
Hi,
so hab nun die erste Version umgesetzt. Ist so das alle IPs die älter sind als 1 Tag wieder gelöscht werden. Nur irgendwie ist die Performance noch nicht so der hit...

Sollte vielleicht doch das mit indizes mal machen^^

Dann noch zu DB-Wartung eine Frage. Also momentan werden die Datensätze per php gekickt, wie / wo finde ich den so ein DB-Wartung ding? bei phpMyAdmin ? oder wo muss ich da suchen?

axo und so sieht es nun aus
www.diabolotreff.de dann auf eine Kategorie und lustig bewerten ;) Falls jemand Bugs findet bitte posten! War leider Nacht wo ich es online gestellt habe und konnte nicht mehr mit anderen Leuten zusammen intensive Fehlersuche machen

Mit freundlichen Grüßen
Martin
Bitte warten ..
Mitglied: DaSam
06.09.2006 um 22:14 Uhr
Hi,

Du hast MySQL am Laufen? Da kenn ich mich leider nicht so aus - das mit der DB-Wartung hat der MS-SQL-Server eingebaut. Ist aber eigentlich nichts anderes als zeitgesteuert Tasks oder DB-Optimierungen laufen zu lassen.

Hast Du shell-Zugang zum Server? Dann könntest Du beispielsweise eben einen cron-Job aufsetzen, der ein Skript ausführt, welches die alten Einträge rauskickt. Wenn es sein muss, kannst Du ja auch per wget ein php-Skript aufrufen vom webserver

Du kannst aber auch in deinem PHP Skript nachschauen, ob der letzte Löschjob schon eine Stunde vorbei ist (in einer Datei abspeichern, wann zuletzt die alten Einträge gelöscht wurden) und dann ggf. am Ende vom PHP Skript die Löschung vornehmen und diesen Zeitstempel wieder abspeichern ...

Aber mach das mal mit den Indexen - auf jedes Feld, nach dem du selektierst, könntest Du einen Index machen - also in deinem Fall auf praktisch alle Tabellenfelder. Ist halt die Frage, ob der SQL-Server dann die Tabellen noch möglichst effizient ins RAM reinbekommt, da die dann schon "etwas" grösser wird, wenn dann noch Indexe drauf sind.

cu,
Alex
Bitte warten ..
Mitglied: ThermoTubbie
07.09.2006 um 13:26 Uhr
Hi Alex,
dann werd ich mal schauen ob ich das mit den zeitstempel hinbekomme. Das mit den Index über die Tablle legen werde ich dann auch mal testen.

Mit freundlichen Grüßen
Martin
Bitte warten ..
Neuester Wissensbeitrag
Ähnliche Inhalte
Firewall
gelöst Site-to-Site-VPN und Cisco VPN-Client von gleicher IP (2)

Frage von TripleDouble zum Thema Firewall ...

Erkennung und -Abwehr
Backdoor in IP-Kameras von Sony (3)

Link von Lochkartenstanzer zum Thema Erkennung und -Abwehr ...

Netzwerke
LAN und WLAN je mit gleicher IP (13)

Frage von dauatitsbest zum Thema Netzwerke ...

E-Mail
gelöst Mail Spam fremde IP (10)

Frage von BerndP zum Thema E-Mail ...

Heiß diskutierte Inhalte
Windows Userverwaltung
Ausgeschiedene Mitarbeiter im Unternehmen - was tun mit den AD Konten? (33)

Frage von patz223 zum Thema Windows Userverwaltung ...

LAN, WAN, Wireless
FritzBox, zwei Server, verschiedene Netze (21)

Frage von DavidGl zum Thema LAN, WAN, Wireless ...

Viren und Trojaner
Aufgepasst: Neue Ransomware Goldeneye verbreitet sich rasant (20)

Link von Penny.Cilin zum Thema Viren und Trojaner ...